/*
Theme Name: Casa Colectiva
Theme URI: https://partnercollection.mvp.sbarron.com
Description: Curated Partner Collection — a WordPress property-listing module. Custom post type, structured property fields, filterable listing grid, single-property pages, and a Request-a-Quote flow. Built for Job #13009.
Author: Barron AI Solutions
Version: 1.0.0
Template: hello-elementor
Text Domain: casa-colectiva
*/

/* ----------------------------------------------------------------
   Design tokens — ink / white / grey + pink accent (brief-mandated)
   Darks are warm, tinted near-blacks (14110F), not a flat absolute dark.
---------------------------------------------------------------- */
:root {
    --cc-bg:         #FFFFFF;
    --cc-panel:      #F5F4F3;            /* faintly warm grey */
    --cc-panel-2:    #ECEAE8;
    --cc-border:     #E4E2E0;
    --cc-ink:        #14110F;            /* warm near-black */
    --cc-ink-soft:   #2A2622;
    --cc-slate:      #6E6964;            /* warm slate */
    --cc-pink:       #EC4899;
    --cc-pink-dark:  #DB2777;
    --cc-pink-tint:  #FCE7F1;
    --cc-radius:     12px;
    --cc-radius-sm:  7px;
    --cc-shadow:     0 1px 2px rgba(20,17,15,.05), 0 10px 28px rgba(20,17,15,.07);
    --cc-shadow-lg:  0 2px 6px rgba(20,17,15,.06), 0 22px 56px rgba(20,17,15,.14);
    --cc-maxw:       1240px;
    /* faint grain — a data-URI SVG noise tile, the texture layer */
    --cc-grain: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.5'/%3E%3C/svg%3E");
}

* { box-sizing: border-box; }

body {
    margin: 0;
    background: var(--cc-bg);
    color: var(--cc-ink);
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif;
    font-size: 16px;
    line-height: 1.62;
    -webkit-font-smoothing: antialiased;
}
/* page-wide whisper of grain so flat fills never read as plastic */
body::before {
    content: ""; position: fixed; inset: 0; z-index: 1;
    background-image: var(--cc-grain);
    opacity: .025; pointer-events: none;
}
body > * { position: relative; z-index: 2; }

/* Display face: Fraunces (high-contrast serif — curated/luxury register).
   Body face: Inter. A real two-family pairing. Both bundled locally. */
h1, h2, h3, h4 {
    font-family: 'Fraunces', 'Inter', Georgia, 'Times New Roman', serif;
    font-weight: 600;
    letter-spacing: -0.012em;
    line-height: 1.14;
    color: var(--cc-ink);
    margin: 0 0 .5em;
}
h1 { font-size: clamp(2.2rem, 4.6vw, 3.6rem); font-weight: 600; }
h2 { font-size: clamp(1.7rem, 3vw, 2.45rem); }
h3 { font-size: 1.2rem; font-weight: 600; font-family: 'Inter', sans-serif; letter-spacing: -.02em; }
p  { margin: 0 0 1rem; }
a  { color: var(--cc-pink-dark); text-decoration: none; }
a:hover { color: var(--cc-ink); }

img { max-width: 100%; height: auto; display: block; }

.cc-wrap { max-width: var(--cc-maxw); margin: 0 auto; padding: 0 24px; }
.cc-section { padding: 64px 0; }
.cc-panel {
    background: linear-gradient(180deg, var(--cc-panel) 0%, var(--cc-panel-2) 100%);
}
.cc-eyebrow {
    font-size: .8rem; font-weight: 700; letter-spacing: .14em;
    text-transform: uppercase; color: var(--cc-pink-dark); margin: 0 0 .6rem;
    font-family: 'Inter', sans-serif;
}

/* ----------------------------------------------------------------
   Buttons — layered, with hover motion
---------------------------------------------------------------- */
.cc-btn {
    display: inline-flex; align-items: center; justify-content: center;
    gap: .5rem; padding: 13px 24px; border-radius: var(--cc-radius-sm);
    font-family: 'Inter', sans-serif; font-weight: 700; font-size: .95rem;
    cursor: pointer; border: 1.5px solid var(--cc-ink);
    background: linear-gradient(180deg, var(--cc-ink-soft) 0%, var(--cc-ink) 100%);
    color: #fff;
    transition: transform .15s ease, box-shadow .15s ease, filter .15s ease;
    box-shadow: 0 1px 2px rgba(20,17,15,.18);
}
.cc-btn:hover { transform: translateY(-2px); box-shadow: var(--cc-shadow); filter: brightness(1.08); }
.cc-btn--pink {
    border-color: var(--cc-pink);
    background: linear-gradient(180deg, #F25BA6 0%, var(--cc-pink) 100%);
    color: #fff;
}
.cc-btn--pink:hover { filter: brightness(1.05); }
.cc-btn--ghost { background: transparent; color: var(--cc-ink); box-shadow: none; }
.cc-btn--ghost:hover { background: var(--cc-ink); color: #fff; }
.cc-btn--block { width: 100%; }

/* ----------------------------------------------------------------
   Site header
---------------------------------------------------------------- */
.cc-header {
    border-bottom: 1px solid var(--cc-border);
    background: rgba(255,255,255,.92); backdrop-filter: blur(8px);
    position: sticky; top: 0; z-index: 50;
}
.cc-header__inner {
    display: flex; align-items: center; justify-content: space-between;
    height: 72px;
}
.cc-logo {
    font-family: 'Fraunces', serif; font-weight: 600; font-size: 1.4rem;
    letter-spacing: -0.01em; color: var(--cc-ink);
}
.cc-logo span { color: var(--cc-pink); }
.cc-nav { display: flex; gap: 28px; }
.cc-nav a { color: var(--cc-slate); font-weight: 600; font-size: .95rem; font-family: 'Inter', sans-serif; }
.cc-nav a:hover { color: var(--cc-ink); }

/* ----------------------------------------------------------------
   Hero + tab switcher
---------------------------------------------------------------- */
.cc-hero {
    padding: 80px 0 0; text-align: center;
    background:
        radial-gradient(680px 320px at 50% -40px, var(--cc-pink-tint) 0%, rgba(252,231,241,0) 70%),
        var(--cc-bg);
}
.cc-hero p.cc-lead {
    font-size: 1.16rem; color: var(--cc-slate);
    max-width: 620px; margin: 0 auto 2.4rem;
}

.cc-tabs { max-width: 880px; margin: 0 auto; }
.cc-tabs__list {
    display: flex; gap: 6px; padding: 6px;
    background: linear-gradient(180deg, var(--cc-panel) 0%, var(--cc-panel-2) 100%);
    border-radius: var(--cc-radius);
    border: 1px solid var(--cc-border);
}
.cc-tab {
    flex: 1; padding: 14px 18px; border: none; background: transparent;
    border-radius: var(--cc-radius-sm); cursor: pointer;
    font-family: 'Inter', sans-serif; font-weight: 700; font-size: .98rem;
    color: var(--cc-slate); transition: background .2s ease, color .2s ease, box-shadow .2s ease;
}
.cc-tab[aria-selected="true"] {
    background: var(--cc-bg); color: var(--cc-ink);
    box-shadow: var(--cc-shadow);
}
.cc-tab__sub { display: block; font-weight: 500; font-size: .78rem; color: var(--cc-slate); margin-top: 2px; }

.cc-tabpanel {
    margin-top: 22px; opacity: 0; transform: translateY(10px);
    transition: opacity .3s ease, transform .3s ease;
    display: none;
}
.cc-tabpanel.is-active { display: block; }
.cc-tabpanel.is-shown { opacity: 1; transform: translateY(0); }

/* HomeRunner placeholder panel (Tab 1) — honest stand-in */
.cc-homerunner {
    border: 1.5px dashed var(--cc-border); border-radius: var(--cc-radius);
    padding: 52px 32px; text-align: center;
    background: linear-gradient(180deg, var(--cc-panel) 0%, var(--cc-panel-2) 100%);
}
.cc-homerunner h3 { color: var(--cc-slate); }
.cc-homerunner p { color: var(--cc-slate); max-width: 460px; margin: .4rem auto 0; font-size: .95rem; }

/* ----------------------------------------------------------------
   City filter
---------------------------------------------------------------- */
.cc-filter {
    display: flex; gap: 12px; flex-wrap: wrap; align-items: center;
    margin-bottom: 28px;
}
.cc-filter__input {
    flex: 1; min-width: 240px; padding: 13px 16px;
    border: 1.5px solid var(--cc-border); border-radius: var(--cc-radius-sm);
    font-family: 'Inter', sans-serif; font-size: .98rem; color: var(--cc-ink);
    background: var(--cc-bg);
}
.cc-filter__input:focus { outline: none; border-color: var(--cc-pink); box-shadow: 0 0 0 3px var(--cc-pink-tint); }
.cc-filter__count { color: var(--cc-slate); font-size: .9rem; font-weight: 600; }

/* ----------------------------------------------------------------
   Listing card grid
---------------------------------------------------------------- */
.cc-grid {
    display: grid; gap: 26px;
    grid-template-columns: repeat(3, 1fr);
}
.cc-card {
    border: 1px solid var(--cc-border); border-radius: var(--cc-radius);
    overflow: hidden; background: var(--cc-bg);
    display: flex; flex-direction: column;
    box-shadow: 0 1px 2px rgba(20,17,15,.04);
    transition: transform .2s ease, box-shadow .2s ease;
}
.cc-card:hover { transform: translateY(-5px); box-shadow: var(--cc-shadow-lg); }
.cc-card__media { position: relative; aspect-ratio: 4 / 3; overflow: hidden; background: var(--cc-panel); }
.cc-card__media img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s ease; }
.cc-card:hover .cc-card__media img { transform: scale(1.05); }
.cc-badge {
    position: absolute; top: 12px; left: 12px;
    padding: 6px 11px; border-radius: 999px;
    font-size: .72rem; font-weight: 700; letter-spacing: .03em;
    font-family: 'Inter', sans-serif;
    background: var(--cc-ink); color: #fff;
    box-shadow: 0 2px 8px rgba(20,17,15,.25);
}
.cc-badge--luxury { background: linear-gradient(180deg, #F25BA6, var(--cc-pink)); }
.cc-badge--latam  { background: var(--cc-ink); }
.cc-card__body { padding: 18px 18px 20px; display: flex; flex-direction: column; flex: 1; }
.cc-card__name { font-family: 'Fraunces', serif; font-size: 1.2rem; font-weight: 600; letter-spacing: -.01em; margin: 0 0 3px; }
.cc-card__loc  { color: var(--cc-slate); font-size: .9rem; margin: 0 0 12px; }
.cc-card__meta {
    display: flex; gap: 14px; flex-wrap: wrap;
    color: var(--cc-slate); font-size: .85rem; margin: 0 0 16px;
}
.cc-card__meta span { display: inline-flex; align-items: center; gap: 5px; }
.cc-card__foot {
    margin-top: auto; display: flex; align-items: center; justify-content: space-between;
    gap: 12px; padding-top: 14px; border-top: 1px solid var(--cc-border);
}
.cc-card__price b { font-size: 1.18rem; font-weight: 800; font-family: 'Inter', sans-serif; }
.cc-card__price small { color: var(--cc-slate); font-weight: 500; }

.cc-empty {
    text-align: center; padding: 64px 24px;
    border: 1px dashed var(--cc-border); border-radius: var(--cc-radius);
    color: var(--cc-slate);
    background: linear-gradient(180deg, var(--cc-panel) 0%, rgba(236,234,232,0) 100%);
}
.cc-empty h3 { color: var(--cc-ink); }

/* ----------------------------------------------------------------
   Single property
---------------------------------------------------------------- */
.cc-single__hero { display: grid; grid-template-columns: 1fr 1fr; gap: 6px; }
.cc-single__hero img { width: 100%; height: 100%; object-fit: cover; aspect-ratio: 3/2; }
.cc-single__head { padding: 36px 0 8px; }
.cc-single__cols { display: grid; grid-template-columns: 1fr 360px; gap: 48px; padding-bottom: 64px; }
.cc-amenities { display: grid; grid-template-columns: repeat(2,1fr); gap: 10px; margin: 16px 0; }
.cc-amenity {
    display: flex; align-items: center; gap: 8px;
    padding: 10px 12px;
    background: linear-gradient(180deg, var(--cc-panel) 0%, var(--cc-panel-2) 100%);
    border-radius: var(--cc-radius-sm); font-size: .92rem;
}
.cc-quotebox {
    border: 1px solid var(--cc-border); border-radius: var(--cc-radius);
    padding: 24px; position: sticky; top: 96px; box-shadow: var(--cc-shadow);
    background: var(--cc-bg);
}
.cc-gallery { display: grid; grid-template-columns: repeat(3,1fr); gap: 8px; margin: 20px 0; }
.cc-gallery img { aspect-ratio: 1; object-fit: cover; border-radius: var(--cc-radius-sm); transition: transform .25s ease; }
.cc-gallery img:hover { transform: scale(1.03); }

/* ----------------------------------------------------------------
   Quote modal
---------------------------------------------------------------- */
.cc-modal {
    position: fixed; inset: 0; z-index: 200;
    display: none; align-items: center; justify-content: center;
    background: rgba(20,17,15,.58); padding: 24px;
    backdrop-filter: blur(3px);
}
.cc-modal.is-open { display: flex; }
.cc-modal__card {
    background: #fff; border-radius: var(--cc-radius);
    max-width: 480px; width: 100%; padding: 32px;
    box-shadow: var(--cc-shadow-lg); max-height: 90vh; overflow-y: auto;
}
.cc-modal__card h3 { font-family: 'Fraunces', serif; font-size: 1.5rem; font-weight: 600; }
.cc-modal__prop { color: var(--cc-pink-dark); font-weight: 700; font-size: .9rem; margin: 0 0 18px; font-family: 'Inter', sans-serif; }
.cc-field { margin-bottom: 14px; }
.cc-field label { display: block; font-size: .85rem; font-weight: 600; margin-bottom: 5px; font-family: 'Inter', sans-serif; }
.cc-field input, .cc-field textarea {
    width: 100%; padding: 11px 13px; font-family: 'Inter', sans-serif; font-size: .95rem;
    border: 1.5px solid var(--cc-border); border-radius: var(--cc-radius-sm);
    color: var(--cc-ink);
}
.cc-field input:focus, .cc-field textarea:focus { outline: none; border-color: var(--cc-pink); box-shadow: 0 0 0 3px var(--cc-pink-tint); }
.cc-modal__close {
    background: none; border: none; font-size: 1.5rem; cursor: pointer;
    color: var(--cc-slate); float: right; line-height: 1;
}
.cc-modal__ok { text-align: center; padding: 20px 0; }
.cc-modal__ok .cc-check {
    width: 56px; height: 56px; border-radius: 999px;
    background: linear-gradient(180deg, #F25BA6, var(--cc-pink));
    color: #fff; display: flex; align-items: center; justify-content: center;
    margin: 0 auto 16px; font-size: 1.6rem; font-weight: 800;
    box-shadow: 0 6px 18px rgba(236,72,153,.4);
}

/* ----------------------------------------------------------------
   Footer
---------------------------------------------------------------- */
.cc-footer {
    border-top: 1px solid var(--cc-border);
    background: linear-gradient(180deg, var(--cc-panel) 0%, var(--cc-panel-2) 100%);
    padding: 40px 0; margin-top: 40px;
}
.cc-footer__inner { display: flex; justify-content: space-between; flex-wrap: wrap; gap: 16px; color: var(--cc-slate); font-size: .9rem; }

/* ----------------------------------------------------------------
   Responsive — QA breakpoints 1440 / 1280 / 768 / 375
---------------------------------------------------------------- */
@media (max-width: 1024px) {
    .cc-grid { grid-template-columns: repeat(2, 1fr); }
    .cc-single__cols { grid-template-columns: 1fr; }
    .cc-quotebox { position: static; }
}
@media (max-width: 680px) {
    .cc-grid { grid-template-columns: 1fr; }
    .cc-single__hero { grid-template-columns: 1fr; }
    .cc-gallery { grid-template-columns: repeat(2,1fr); }
    .cc-amenities { grid-template-columns: 1fr; }
    .cc-section { padding: 44px 0; }
    .cc-nav { display: none; }
    .cc-tab__sub { display: none; }
    .cc-mobile-cta {
        position: fixed; left: 0; right: 0; bottom: 0; z-index: 60;
        background: #fff; border-top: 1px solid var(--cc-border);
        padding: 12px 16px; display: flex;
        box-shadow: 0 -4px 20px rgba(20,17,15,.1);
    }
}
.cc-mobile-cta { display: none; }
