/* theme.css — Simple Homes public theme ("Electric Cobalt").
   Minimal real-estate skin: pure white, photo-dominant cards, bold all-sans
   type (Inter Tight display / Inter body), electric cobalt accent.
   Selector inventory and JS hooks match the Series skin — only values changed.
   Admin UI uses site.css and is unaffected by this file. */

:root{
  --bg:        #ffffff;                       /* pure white */
  --bg-deep:   oklch(0.97 0.005 255);         /* pale cool blue-gray panel */
  --ink:       oklch(0.21 0.015 264);         /* near-black, cool cast */
  --ink-soft:  oklch(0.42 0.02 262);
  --muted:     oklch(0.555 0.015 262);
  --line:      oklch(0.21 0.015 264 / 0.14);
  --line-soft: oklch(0.21 0.015 264 / 0.08);
  --accent:    oklch(0.546 0.245 263);        /* electric cobalt ~#2563EB */
  --accent-deep: oklch(0.488 0.243 264);      /* deep cobalt ~#1D4ED8 (hover + JS validation border) */
  --paper-edge: oklch(0.21 0.015 264 / 0.05);

  /* --serif now carries the bold display SANS; the .serif class in markup is the hook. */
  --serif: "Inter Tight", system-ui, -apple-system, sans-serif;
  --sans:  "Inter", system-ui, -apple-system, sans-serif;

  --maxw: 1340px;
  --gutter: clamp(20px, 5vw, 80px);
  --ease: cubic-bezier(.22,.61,.36,1);
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility; }
body{
  margin:0; background:var(--bg); color:var(--ink);
  font-family:var(--sans); font-size:16.5px; line-height:1.6; font-weight:400;
  letter-spacing:0;
  overflow-x:hidden;
}
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } }

::selection{ background:var(--accent); color:#fff; }

a{ color:inherit; text-decoration:none; }
img{ display:block; max-width:100%; }
h1,h2,h3,h4{ margin:0; font-weight:400; }
p{ margin:0; }
button{ font-family:inherit; cursor:pointer; }

.wrap{ max-width:var(--maxw); margin:0 auto; padding-inline:var(--gutter); }

.eyebrow{
  font-family:var(--sans); font-size:11.5px; font-weight:700;
  text-transform:uppercase; letter-spacing:.22em; color:var(--accent);
  display:inline-flex; align-items:center; gap:.7em;
}
.eyebrow::before{ content:""; width:28px; height:2px; background:var(--accent); display:inline-block; }
.eyebrow.center::after{ content:""; width:28px; height:2px; background:var(--accent); display:inline-block; }

.serif{ font-family:var(--serif); }

/* ---------- reveal ---------- */
/* resting state is VISIBLE; hide-then-reveal only enabled once JS confirms the observer works */
html.reveal-on .reveal{ opacity:0; transform:translateY(18px); transition:opacity .8s var(--ease), transform .8s var(--ease); }
html.reveal-on .reveal.in{ opacity:1; transform:none; }
html.reveal-on .reveal.d1{ transition-delay:.08s; }
html.reveal-on .reveal.d2{ transition-delay:.16s; }
html.reveal-on .reveal.d3{ transition-delay:.24s; }

/* ================= NAV ================= */
header.nav{
  position:fixed; top:0; left:0; right:0; z-index:50;
  transition:background .5s var(--ease), border-color .5s var(--ease), backdrop-filter .5s;
  border-bottom:1px solid transparent;
}
header.nav.scrolled{
  background:oklch(1 0 0 / 0.85);
  backdrop-filter:blur(14px) saturate(1.2);
  border-bottom:1px solid var(--line-soft);
}
.nav-inner{
  max-width:var(--maxw); margin:0 auto; padding:0 var(--gutter);
  height:76px; display:flex; align-items:center; justify-content:space-between; gap:24px;
}
.brand{ display:flex; align-items:center; gap:12px; }
.brand .mark{
  width:36px; height:36px; border:none; border-radius:10px; background:var(--accent); color:#fff;
  display:grid; place-items:center; font-family:var(--serif); font-weight:800; font-size:16px;
  letter-spacing:0; transition:transform .5s var(--ease);
}
.brand:hover .mark{ transform:rotate(-8deg); }
.brand .wm{ font-family:var(--serif); font-size:18px; font-weight:800; letter-spacing:-0.02em; }
.brand .wm small{ font-family:var(--sans); display:block; font-size:9px; font-weight:600; letter-spacing:.24em; text-transform:uppercase; color:var(--muted); margin-top:2px; }

nav.links{ display:flex; align-items:center; gap:32px; }
nav.links a{ font-size:13px; font-weight:600; letter-spacing:.02em; color:var(--ink-soft); position:relative; padding:6px 0; transition:color .3s; }
nav.links a::after{ content:""; position:absolute; left:0; bottom:0; height:2px; width:0; background:var(--accent); transition:width .4s var(--ease); }
nav.links a:hover{ color:var(--ink); }
nav.links a:hover::after{ width:100%; }

.nav-right{ display:flex; align-items:center; gap:18px; }
.lang{
  display:inline-flex; align-items:center; border:1px solid var(--line); border-radius:100px; overflow:hidden;
  font-size:11px; font-weight:700; letter-spacing:.08em;
}
.lang button{ background:none; border:none; padding:7px 12px; color:var(--muted); letter-spacing:.1em; transition:color .3s, background .3s; }
.lang button.on{ background:var(--ink); color:#fff; }
.design-toggle{
  display:inline-flex; align-items:center; gap:8px;
  font-size:10.5px; font-weight:600; letter-spacing:.12em; text-transform:uppercase; color:var(--muted);
}
.design-toggle .dt-label{ color:var(--muted); }
.design-toggle a{ transition:color .3s; }
.design-toggle a.on{ color:var(--accent); font-weight:700; }
.btn-cta{
  font-size:12px; font-weight:700; letter-spacing:.08em; text-transform:uppercase;
  padding:12px 24px; border:1px solid var(--accent); border-radius:100px; background:var(--accent); color:#fff;
  transition:background .4s var(--ease), border-color .4s var(--ease), transform .4s var(--ease);
}
.btn-cta:hover{ background:var(--ink); border-color:var(--ink); transform:translateY(-1px); }

.menu-toggle{ display:none; background:none; border:none; color:var(--ink); }

/* ================= HERO ================= */
.hero{ padding-top:150px; padding-bottom:84px; position:relative; }
.hero-grid{ display:grid; grid-template-columns:0.95fr 1.05fr; gap:clamp(28px,5vw,76px); align-items:stretch; }
.hero-copy{ display:flex; flex-direction:column; justify-content:center; }
.hero-copy .greet{ margin-bottom:26px; }
.hero h1{
  font-family:var(--serif); font-weight:800;
  font-size:clamp(54px, 8.5vw, 128px); line-height:0.95; letter-spacing:-0.035em;
}
.hero h1 em{ font-style:normal; font-weight:800; color:var(--accent); }
.hero h1 .line2{ display:block; }
.hero-sub{
  margin-top:28px; max-width:32ch; color:var(--ink-soft); font-size:18px; line-height:1.6;
}
.hero-actions{ margin-top:38px; display:flex; align-items:center; gap:26px; flex-wrap:wrap; }
.link-arrow{ display:inline-flex; align-items:center; gap:10px; font-size:13.5px; letter-spacing:.01em; font-weight:600; color:var(--ink); }
.link-arrow .ar{ transition:transform .45s var(--ease); }
.link-arrow:hover .ar{ transform:translateX(7px); }
.filled{
  background:var(--accent); color:#fff; padding:14px 28px; border-radius:100px;
  font-size:12px; letter-spacing:.08em; text-transform:uppercase; font-weight:700;
  transition:background .4s, transform .4s var(--ease);
}
.filled:hover{ background:var(--ink); transform:translateY(-2px); }

.hero-figure{ position:relative; }
.hero-figure .ph{ aspect-ratio:4/5; height:100%; }
.hero-figure .cap{
  position:absolute; left:0; bottom:-32px; font-family:var(--sans); font-size:10.5px; font-weight:600;
  letter-spacing:.18em; text-transform:uppercase; color:var(--muted);
}
.hero-figure .idx{
  position:absolute; top:-30px; right:0; font-family:var(--sans); font-style:normal; font-weight:800;
  font-size:12px; letter-spacing:.1em; color:var(--accent);
}

/* placeholder visual */
.ph{
  position:relative; width:100%; background:var(--bg-deep);
  border:none; overflow:hidden;
}
.ph::before{
  content:""; position:absolute; inset:0;
  background-image:repeating-linear-gradient(-45deg, transparent 0 13px, var(--paper-edge) 13px 14px);
}
.ph .ph-label{
  position:absolute; inset:0; margin:auto; height:fit-content; width:fit-content;
  font-family:var(--sans); font-size:10px; font-weight:600; letter-spacing:.2em; text-transform:uppercase;
  color:var(--muted); background:#fff; padding:7px 13px; border:1px solid var(--line-soft); border-radius:100px;
  display:flex; align-items:center; gap:8px;
}
.ph .ph-label::before{ content:""; width:6px; height:6px; border-radius:50%; background:var(--accent); }

/* photo fills the .ph panel when present */
.ph img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }

/* ============== MARQUEE / divider ============== */
.ticker{ border:none; background:var(--accent); color:#fff; overflow:hidden; padding:14px 0; margin-top:34px; }
.ticker-track{ display:flex; gap:56px; width:max-content; animation:slide 38s linear infinite; }
@media (prefers-reduced-motion: reduce){ .ticker-track{ animation:none; } }
.ticker-track span{ font-family:var(--sans); font-style:normal; font-weight:700; font-size:13px; letter-spacing:.2em; text-transform:uppercase; color:#fff; white-space:nowrap; display:inline-flex; align-items:center; gap:56px; }
.ticker-track span::after{ content:"·"; color:oklch(1 0 0 / 0.55); }
@keyframes slide{ from{ transform:translateX(0);} to{ transform:translateX(-50%);} }

/* ================= SECTION HEAD ================= */
section{ padding-block:clamp(72px, 10vw, 132px); }
.sec-head{ display:flex; justify-content:space-between; align-items:flex-end; gap:30px; margin-bottom:54px; }
.sec-head h2{ font-family:var(--serif); font-weight:800; font-size:clamp(36px,5vw,64px); line-height:1; letter-spacing:-0.03em; }
.sec-head .meta{ font-size:13px; letter-spacing:.02em; color:var(--muted); max-width:34ch; text-align:right; }

/* ================= CATALOG ================= */
.cat-group + .cat-group{ margin-top:80px; }
.grp-label{ display:flex; align-items:center; gap:16px; margin-bottom:32px; }
.grp-label h3{ font-family:var(--sans); font-size:12px; font-weight:800; letter-spacing:.2em; text-transform:uppercase; color:var(--ink); }
.grp-label .rule{ flex:1; height:1px; background:var(--line-soft); }
.grp-label .count{ font-family:var(--sans); font-style:normal; font-weight:700; font-size:12px; letter-spacing:.08em; color:var(--accent); }

.feat-grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(22px,3vw,52px); }
.feat{ display:flex; flex-direction:column; }
.feat .ph{ aspect-ratio:5/4; }
.feat .ph img, .gen .ph img{ transition:transform .8s var(--ease); }
.feat:hover .ph img, .gen:hover .ph img{ transform:scale(1.04); }
.feat .body{ padding-top:20px; display:flex; gap:18px; justify-content:space-between; align-items:flex-start; border-top:2px solid var(--ink); margin-top:18px; }
.feat .body .t h4{ font-family:var(--serif); font-size:24px; font-weight:700; line-height:1.15; letter-spacing:-0.015em; }
.feat .body .t p{ margin-top:8px; color:var(--ink-soft); font-size:14px; max-width:36ch; }
.price{ font-family:var(--sans); font-weight:800; font-size:20px; letter-spacing:-0.01em; white-space:nowrap; text-align:right; }
.price small{ display:block; font-weight:600; font-size:10px; letter-spacing:.18em; text-transform:uppercase; color:var(--muted); margin-bottom:3px; }

.gen-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(18px,2.6vw,44px); }
.gen{ }
.gen .ph{ aspect-ratio:4/3; }
.gen .body{ padding-top:16px; display:flex; justify-content:space-between; gap:14px; align-items:flex-start; border-top:1px solid var(--line); margin-top:16px; }
.gen .body h4{ font-family:var(--serif); font-size:19px; font-weight:700; letter-spacing:-0.015em; }
.gen .body p{ margin-top:6px; color:var(--ink-soft); font-size:13.5px; }
.gen .price{ font-size:16px; }

/* ================= CONTACT ================= */
.contact{ background:var(--bg-deep); }
.contact-grid{ display:grid; grid-template-columns:0.8fr 1.2fr; gap:clamp(32px,6vw,90px); align-items:start; }
.contact-aside h2{ font-family:var(--serif); font-weight:800; font-size:clamp(34px,4.4vw,58px); line-height:1.02; letter-spacing:-0.03em; margin-top:22px; }
.contact-aside p{ margin-top:22px; color:var(--ink-soft); max-width:32ch; font-size:15.5px; }
.contact-aside .seal{
  margin-top:40px; width:96px; height:96px; border:2px solid var(--accent); border-radius:50%;
  display:grid; place-items:center; font-family:var(--sans); font-style:normal; font-weight:700;
  color:var(--accent); font-size:11px; letter-spacing:.1em; text-transform:uppercase; text-align:center; line-height:1.35;
}

form{ display:grid; gap:30px; }
.f-row{ display:grid; grid-template-columns:1fr 1fr; gap:30px; }
.field{ position:relative; }
.field label{ display:block; font-size:11px; letter-spacing:.18em; text-transform:uppercase; color:var(--muted); margin-bottom:11px; font-weight:700; }
.field label .req{ color:var(--accent-deep); }
.field input, .field textarea{
  width:100%; background:transparent; border:none; border-bottom:1.5px solid var(--line);
  padding:9px 0; font-family:var(--sans); font-size:16px; color:var(--ink); transition:border-color .4s;
}
.field textarea{ resize:vertical; min-height:96px; }
.field input:focus, .field textarea:focus{ outline:none; border-bottom-color:var(--ink); }
.field input::placeholder, .field textarea::placeholder{ color:oklch(0.555 0.015 262 / 0.55); }
.form-foot{ display:flex; justify-content:space-between; align-items:center; gap:20px; flex-wrap:wrap; }
.form-note{ font-size:12.5px; color:var(--muted); max-width:30ch; }
button.submit{
  background:var(--accent); color:#fff; border:1px solid var(--accent); border-radius:100px;
  padding:16px 36px; font-size:12px; letter-spacing:.1em; text-transform:uppercase; font-weight:700;
  transition:background .4s, border-color .4s, transform .4s var(--ease); display:inline-flex; align-items:center; gap:12px;
}
button.submit:hover{ background:var(--ink); border-color:var(--ink); transform:translateY(-2px); }
button.submit .ar{ transition:transform .4s var(--ease); }
button.submit:hover .ar{ transform:translateX(5px); }
.form-done{ font-family:var(--sans); font-style:normal; font-weight:700; font-size:15px; color:var(--accent-deep); display:none; }
form.sent .form-done{ display:block; }
form.sent .form-foot button.submit{ opacity:.4; pointer-events:none; }

/* ================= HOURS ================= */
.hours-grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(32px,6vw,90px); align-items:center; }
.hours-list{ border-top:2px solid var(--ink); }
.hours-list .row{ display:flex; justify-content:space-between; align-items:baseline; padding:24px 4px; border-bottom:1px solid var(--line-soft); }
.hours-list .row .day{ font-family:var(--serif); font-size:22px; font-weight:800; letter-spacing:-0.02em; }
.hours-list .row .time{ font-size:14px; letter-spacing:.04em; color:var(--muted); }
.hours-list .row.closed .time{ color:var(--accent-deep); font-style:normal; font-family:var(--sans); font-weight:700; font-size:11px; letter-spacing:.14em; text-transform:uppercase; }
.hours-fig .ph{ aspect-ratio:0.92; }

/* ================= FOOTER ================= */
footer{ background:var(--ink); color:#fff; padding-block:clamp(64px,8vw,104px); }
footer ::selection{ background:var(--accent); color:#fff; }
.foot-top{ display:grid; grid-template-columns:1.3fr 1fr 1fr; gap:40px; padding-bottom:64px; border-bottom:1px solid oklch(1 0 0 / 0.12); }
.foot-brand .big{ font-family:var(--serif); font-size:clamp(40px,6vw,80px); line-height:0.95; font-weight:800; letter-spacing:-0.03em; }
.foot-brand .big em{ font-style:normal; color:oklch(0.65 0.19 260); }
.foot-brand p{ margin-top:22px; color:oklch(1 0 0 / 0.62); max-width:30ch; font-size:14.5px; }
.foot-col h5{ font-family:var(--sans); font-size:11px; font-weight:700; letter-spacing:.2em; text-transform:uppercase; color:oklch(1 0 0 / 0.5); margin-bottom:20px; }
.foot-col a, .foot-col p{ display:block; color:oklch(1 0 0 / 0.78); font-size:14.5px; margin-bottom:12px; transition:color .3s; }
.foot-col a:hover{ color:oklch(0.65 0.19 260); }
.foot-bot{ display:flex; justify-content:space-between; align-items:center; gap:20px; padding-top:34px; flex-wrap:wrap; }
.foot-bot .small{ font-size:12px; letter-spacing:.04em; color:oklch(1 0 0 / 0.5); }
.foot-bot .mark2{ font-family:var(--serif); font-style:normal; font-weight:700; font-size:15px; color:oklch(1 0 0 / 0.85); }

/* ================= FLASH (server messages) ================= */
.flashes{ max-width:var(--maxw); margin:96px auto 0; padding-inline:var(--gutter); display:grid; gap:10px; }
.flash{ padding:14px 18px; border:1px solid var(--line); border-radius:8px; font-size:14px; background:#fff; }
.flash-error{ border-color:var(--accent-deep); color:var(--accent-deep); }

/* ================= CONFIRMATION PANEL ================= */
.confirm{ padding-top:170px; }
.confirm .wrap{ max-width:820px; }
.confirm .eyebrow{ margin-bottom:22px; }
.confirm h1{ font-family:var(--serif); font-weight:800; font-size:clamp(48px,7vw,96px); line-height:1; letter-spacing:-0.035em; }
.confirm p{ margin-top:24px; color:var(--ink-soft); font-size:17px; max-width:46ch; }
.confirm .ticket{ font-family:var(--sans); font-style:normal; font-weight:700; color:var(--accent-deep); }
.confirm-actions{ margin-top:40px; display:flex; align-items:center; gap:26px; flex-wrap:wrap; }
.confirm-actions .small{ font-size:12.5px; color:var(--muted); }
.confirm .small{ font-size:13px; color:var(--muted); }

/* ================= RESPONSIVE ================= */
@media (max-width:980px){
  nav.links{ display:none; }
  .menu-toggle{ display:inline-flex; }
  .hero-grid{ grid-template-columns:1fr; }
  .hero-figure{ display:block; margin-top:40px; }
  .hero-figure .ph{ aspect-ratio:16/10; height:auto; }
  .feat-grid{ grid-template-columns:1fr; }
  .gen-grid{ grid-template-columns:1fr 1fr; }
  .contact-grid, .hours-grid{ grid-template-columns:1fr; }
  .hours-fig{ display:none; }
  .foot-top{ grid-template-columns:1fr; gap:44px; }
}
@media (max-width:560px){
  .nav-right .btn-cta{ display:none; }
  .gen-grid{ grid-template-columns:1fr; }
  .f-row{ grid-template-columns:1fr; }
  .sec-head{ flex-direction:column; align-items:flex-start; }
  .sec-head .meta{ text-align:left; }
}

/* ================= HOMES (vertical) ================= */
/* Operation filter chips */
.op-chips{ display:flex; gap:10px; margin-bottom:44px; flex-wrap:wrap; }
.chip-op{
  background:transparent; border:1px solid var(--line); border-radius:100px;
  padding:10px 24px; font-family:var(--sans); font-size:11.5px; letter-spacing:.12em;
  text-transform:uppercase; font-weight:700; color:var(--ink-soft);
  transition:all .35s var(--ease); cursor:pointer;
}
.chip-op:hover{ border-color:var(--ink); color:var(--ink); }
.chip-op.on{ background:var(--accent); border-color:var(--accent); color:#fff; }
.empty-filter{ display:none; color:var(--muted); font-size:14px; margin-top:8px; }
.empty-filter.show{ display:block; }

/* Operation badge next to the title */
.op{
  display:inline-block; vertical-align:middle; margin-left:10px;
  font-family:var(--sans); font-size:10px; font-weight:700; letter-spacing:.14em;
  text-transform:uppercase; border-radius:100px; padding:4px 12px; white-space:nowrap;
}
.op-venta{ background:var(--accent); color:#fff; }
.op-renta{ border:1px solid var(--ink); color:var(--ink); }

/* Meta line + amenities */
.meta-line{ margin-top:8px; font-size:12.5px; font-weight:500; letter-spacing:.04em; color:var(--muted); }
.amen{ margin-top:10px; display:flex; flex-wrap:wrap; gap:7px; }
.amen span{
  font-size:11px; letter-spacing:.04em; color:var(--ink-soft);
  border:1px solid var(--line-soft); border-radius:100px; padding:4px 12px;
}

/* Gallery thumbnail strip (plain links; JS swaps the cover in place) */
.thumbs{
  display:flex; gap:8px; margin-top:10px; overflow-x:auto; padding-bottom:4px;
  scroll-snap-type:x proximity; scrollbar-width:thin;
}
.thumbs a{ flex:0 0 auto; scroll-snap-align:start; border-bottom:none; }
.thumbs img{
  width:72px; height:54px; object-fit:cover; display:block;
  border:1px solid var(--line-soft); transition:border-color .3s;
}
.thumbs a:hover img{ border-color:var(--accent); }

/* Card aside: price over the interest button */
.aside-col{ display:flex; flex-direction:column; align-items:flex-end; gap:12px; }
.price .per{ font-weight:500; font-size:13px; color:var(--muted); }
button.act{
  background:transparent; border:1px solid var(--ink); border-radius:100px;
  padding:10px 22px; font-family:var(--sans); font-size:11px; letter-spacing:.12em;
  text-transform:uppercase; font-weight:700; color:var(--ink);
  transition:all .35s var(--ease); cursor:pointer; white-space:nowrap;
}
button.act:hover{ background:var(--accent); border-color:var(--accent); color:#fff; }

/* Listing select in the inquiry form, styled like the inputs */
.field select{
  width:100%; background:transparent; border:none; border-bottom:1.5px solid var(--line);
  padding:9px 0; font-family:var(--sans); font-size:16px; color:var(--ink);
  transition:border-color .4s; appearance:none; border-radius:0;
}
.field select:focus{ outline:none; border-bottom-color:var(--ink); }

/* How-I-work steps */
.steps{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(18px,2.6vw,44px); }
.step{ border-top:1px solid var(--line); padding-top:18px; }
.step .idx{ font-family:var(--sans); font-style:normal; font-weight:800; font-size:13px; letter-spacing:.08em; color:var(--accent); }
.step h4{ font-family:var(--serif); font-size:18px; font-weight:700; letter-spacing:-0.01em; margin-top:10px; }
.step p{ margin-top:8px; color:var(--ink-soft); font-size:14px; max-width:30ch; }

@media (max-width: 860px){
  .steps{ grid-template-columns:1fr; gap:26px; }
  .aside-col{ align-items:flex-start; }
}
