/* ============================================================================
   CASE D'ARTE — proof of concept stylesheet
   Aesthetic: refined Italian editorial · Apple-grade restraint · warm plaster
   Typography sized up for legibility (older eyes). One wine accent. No fluff.
   ========================================================================== */

/* ── Fonts ─────────────────────────────────────────────────────────────── */
@font-face{font-family:"Fraunces";src:url("../fonts/fraunces-400.woff2?v=2") format("woff2");font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:"Fraunces";src:url("../fonts/fraunces-500.woff2?v=2") format("woff2");font-weight:500;font-style:normal;font-display:swap}
@font-face{font-family:"Fraunces";src:url("../fonts/fraunces-600.woff2?v=2") format("woff2");font-weight:600;font-style:normal;font-display:swap}
@font-face{font-family:"Fraunces";src:url("../fonts/fraunces-italic-400.woff2?v=2") format("woff2");font-weight:400;font-style:italic;font-display:swap}
@font-face{font-family:"Hanken Grotesk";src:url("../fonts/hanken-grotesk-400.woff2") format("woff2");font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:"Hanken Grotesk";src:url("../fonts/hanken-grotesk-500.woff2") format("woff2");font-weight:500;font-style:normal;font-display:swap}
@font-face{font-family:"Hanken Grotesk";src:url("../fonts/hanken-grotesk-700.woff2") format("woff2");font-weight:700;font-style:normal;font-display:swap}

/* ── Tokens ────────────────────────────────────────────────────────────── */
:root{
  --paper:#f6f1e8;        /* warm plaster background          */
  --paper-2:#fbf8f1;      /* lifted card surface              */
  --ink:#211c16;          /* warm near-black text             */
  --ink-soft:#5d5347;     /* muted secondary text             */
  --wine:#7c2b27;         /* deep Ruchè red — primary action  */
  --wine-deep:#5f1f1c;
  --clay:#b0633e;         /* terracotta — eyebrows / accents  */
  --line:#e3d9c8;         /* hairline borders                 */
  --line-soft:#ece3d4;
  --gold:#c9a227;

  --serif:"Fraunces",Georgia,"Times New Roman",serif;
  --sans:"Hanken Grotesk",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;

  --maxw:1180px;
  --radius:16px;
  --radius-pill:999px;
  --shadow-s:0 1px 2px rgba(33,28,22,.06), 0 6px 18px rgba(33,28,22,.06);
  --shadow-m:0 4px 10px rgba(33,28,22,.08), 0 22px 50px rgba(33,28,22,.12);
  --ease:cubic-bezier(.22,.61,.36,1);
}

/* ── Reset / base ──────────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{
  margin:0;background:var(--paper);color:var(--ink);
  font-family:var(--sans);
  font-size:1.1875rem;          /* 19px base — generous for legibility */
  line-height:1.65;font-weight:400;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer}
h1,h2,h3{font-family:var(--serif);font-weight:500;line-height:1.08;margin:0;letter-spacing:-.01em;
  font-variation-settings:"opsz" 120}
p{margin:0}
::selection{background:var(--wine);color:#fff}

:focus-visible{outline:3px solid var(--clay);outline-offset:3px;border-radius:4px}

.wrap{width:min(100% - 2.5rem,var(--maxw));margin-inline:auto}
.eyebrow{font-family:var(--sans);font-weight:700;font-size:.78rem;letter-spacing:.18em;
  text-transform:uppercase;color:var(--clay)}
.skip{position:absolute;left:-9999px}
.skip:focus{left:1rem;top:1rem;background:var(--ink);color:#fff;padding:.7rem 1rem;border-radius:8px;z-index:99}

/* ── Buttons ───────────────────────────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;gap:.55em;font-family:var(--sans);font-weight:700;
  font-size:1.0625rem;line-height:1;padding:1.05rem 1.7rem;border-radius:var(--radius-pill);
  border:1.5px solid transparent;transition:transform .25s var(--ease),background .25s var(--ease),
  box-shadow .25s var(--ease),color .25s var(--ease);white-space:nowrap}
.btn:active{transform:translateY(1px)}
.btn--primary{background:var(--wine);color:#fdf7ee;box-shadow:0 8px 22px rgba(124,43,39,.28)}
.btn--primary:hover{background:var(--wine-deep);transform:translateY(-2px);box-shadow:0 12px 28px rgba(124,43,39,.34)}
.btn--ghost{background:transparent;color:var(--ink);border-color:var(--ink)}
.btn--ghost:hover{background:var(--ink);color:var(--paper);transform:translateY(-2px)}
.btn--light{background:rgba(255,255,255,.12);color:#fff;border-color:rgba(255,255,255,.55);backdrop-filter:blur(6px)}
.btn--light:hover{background:#fff;color:var(--ink);transform:translateY(-2px)}
.arrow{transition:transform .25s var(--ease)}
.btn:hover .arrow,.txtlink:hover .arrow{transform:translateX(4px)}

.txtlink{font-weight:700;color:var(--wine);display:inline-flex;align-items:center;gap:.4em;
  border-bottom:2px solid transparent;transition:border-color .2s}
.txtlink:hover{border-color:var(--wine)}

/* ── Header ────────────────────────────────────────────────────────────── */
.nav{position:sticky;top:0;z-index:40;background:rgba(246,241,232,.82);
  backdrop-filter:saturate(140%) blur(14px);border-bottom:1px solid transparent;transition:border-color .3s,box-shadow .3s}
.nav.scrolled{border-color:var(--line);box-shadow:0 6px 24px rgba(33,28,22,.05)}
.nav__in{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.95rem 0}
.brand{display:flex;flex-direction:column;line-height:1.05}
.brand b{font-family:var(--serif);font-weight:600;font-size:1.4rem;letter-spacing:.005em}
.brand span{font-family:var(--sans);font-weight:600;font-size:.66rem;letter-spacing:.22em;
  text-transform:uppercase;color:var(--ink-soft);margin-top:.18rem}
.nav__links{display:flex;align-items:center;gap:2rem}
.nav__links a{font-weight:500;font-size:1rem;color:var(--ink-soft);transition:color .2s}
.nav__links a:hover{color:var(--ink)}
.nav__lang{font-size:.82rem;font-weight:600;letter-spacing:.04em;color:var(--ink-soft);
  background:none;border:0;cursor:pointer;font-family:var(--sans);padding:.3rem 0;transition:color .2s}
.nav__lang:hover{color:var(--ink)}
.nav__lang b{color:var(--ink)}
.nav__lang .soon{opacity:.6}
.nav__cta{padding:.7rem 1.25rem;font-size:.98rem}

/* hamburger button — animates to ✕ */
.nav__burger{display:none;background:none;border:0;padding:.5rem;margin:-.5rem -.4rem -.5rem 0;line-height:0}
.nav__burger .bg{display:block;width:26px;height:18px;position:relative}
.nav__burger i{position:absolute;left:0;right:0;height:2.5px;background:var(--ink);border-radius:2px;
  transition:transform .3s var(--ease),opacity .2s var(--ease),top .3s var(--ease),bottom .3s var(--ease)}
.nav__burger i:nth-child(1){top:0}
.nav__burger i:nth-child(2){top:50%;transform:translateY(-50%)}
.nav__burger i:nth-child(3){bottom:0}
.nav__burger.is-open i:nth-child(1){top:50%;transform:translateY(-50%) rotate(45deg)}
.nav__burger.is-open i:nth-child(2){opacity:0}
.nav__burger.is-open i:nth-child(3){bottom:50%;transform:translateY(50%) rotate(-45deg)}

/* mobile dropdown menu */
.mobile-menu{position:absolute;left:0;right:0;top:100%;background:var(--paper);
  border-top:1px solid var(--line-soft);border-bottom:1px solid var(--line);
  box-shadow:0 22px 44px rgba(33,28,22,.14);padding:.6rem 0 1.5rem;
  opacity:0;transform:translateY(-12px);transition:opacity .28s var(--ease),transform .28s var(--ease)}
.mobile-menu[hidden]{display:none}
.mobile-menu.open{opacity:1;transform:none}
.mobile-menu__links{display:flex;flex-direction:column}
.mobile-menu__links a{font-family:var(--serif);font-size:1.45rem;font-weight:500;color:var(--ink);
  padding:.9rem 1.25rem;border-bottom:1px solid var(--line-soft)}
.mobile-menu__links a:active{background:var(--paper-2)}
.mobile-menu__cta{display:flex;justify-content:center;width:calc(100% - 2.5rem);margin:1.3rem 1.25rem 0}

@media(max-width:900px){
  .nav__links,.nav__cta{display:none}
  .nav__burger{display:block}
  .nav__lang{font-size:.9rem}
  .nav__lang .soon{display:none}
}
@media(min-width:901px){ .mobile-menu{display:none} }

/* ── Hero ──────────────────────────────────────────────────────────────── */
.hero{position:relative;min-height:min(92vh,860px);display:flex;align-items:flex-end;
  color:#fdf8ef;overflow:hidden;isolation:isolate}
.hero__img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:-2;
  filter:brightness(.93) contrast(1.03) saturate(1.05);
  transform:scale(1.06);animation:slowzoom 18s var(--ease) forwards}
@keyframes slowzoom{to{transform:scale(1)}}
/* Layered scrim: deep on the LEFT (where text lives), open on the right;
   plus a soft top + bottom anchor. Keeps the landscape airy. */
.hero::after{content:"";position:absolute;inset:0;z-index:-1;background:
  linear-gradient(90deg, rgba(22,15,10,.74) 0%, rgba(22,15,10,.46) 30%, rgba(22,15,10,.10) 58%, transparent 78%),
  linear-gradient(180deg, rgba(18,12,8,.42) 0%, rgba(18,12,8,0) 26%, rgba(18,12,8,.22) 58%, rgba(16,11,7,.72) 100%)}
.hero__in{padding-block:clamp(3rem,8vh,7rem)}
.hero__eyebrow{color:#f4d9b8;text-shadow:0 1px 12px rgba(0,0,0,.4)}
.hero h1{font-size:clamp(2.7rem,6.4vw,5rem);font-weight:600;max-width:15ch;margin:.7rem 0 0;
  text-shadow:0 1px 2px rgba(0,0,0,.45),0 2px 34px rgba(0,0,0,.42)}
.hero h1 em{font-style:italic;font-weight:400;color:#f4cda1}
.hero__sub{max-width:48ch;margin-top:1.3rem;font-size:1.2rem;line-height:1.6;color:#f6eee2;
  text-shadow:0 1px 2px rgba(0,0,0,.5),0 1px 18px rgba(0,0,0,.45)}
.hero__cta{display:flex;flex-wrap:wrap;gap:.9rem;margin-top:2.1rem}
.hero__meta{display:flex;flex-wrap:wrap;gap:1.4rem;margin-top:2.4rem;padding-top:1.5rem;
  border-top:1px solid rgba(255,255,255,.22);max-width:600px}
.hero__meta div{display:flex;flex-direction:column}
.hero__meta b{font-family:var(--serif);font-size:1.5rem;font-weight:500}
.hero__meta span{font-size:.82rem;letter-spacing:.04em;color:#e7d8c4}

/* staggered entrance */
.rise{opacity:0;transform:translateY(22px);animation:rise .9s var(--ease) forwards}
.d1{animation-delay:.12s}.d2{animation-delay:.26s}.d3{animation-delay:.42s}
.d4{animation-delay:.58s}.d5{animation-delay:.74s}
@keyframes rise{to{opacity:1;transform:none}}

/* ── Section scaffolding ───────────────────────────────────────────────── */
section{padding-block:clamp(4.5rem,9vw,8rem)}
.sec-head{max-width:62ch}
.sec-head h2{font-size:clamp(2rem,3.8vw,3.1rem);margin-top:.6rem}
.sec-head p{margin-top:1rem;font-size:1.18rem;color:var(--ink-soft);max-width:56ch}
.center{margin-inline:auto;text-align:center}
.center p{margin-inline:auto}

/* ── Proposition: three pillars ────────────────────────────────────────── */
.pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:2.4rem;margin-top:3.2rem}
.pillar{padding-top:1.4rem;border-top:2px solid var(--clay)}
.pillar .n{font-family:var(--serif);font-size:1.05rem;color:var(--clay);font-weight:600}
.pillar h3{font-size:1.5rem;margin:.5rem 0 .55rem;font-weight:500}
.pillar p{color:var(--ink-soft);font-size:1.05rem}
@media(max-width:760px){.pillars{grid-template-columns:1fr;gap:1.8rem}}

/* ── Houses ────────────────────────────────────────────────────────────── */
.houses{background:linear-gradient(180deg,#efe7d8,var(--paper))}
.house-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.8rem;margin-top:3.4rem}
.card{background:var(--paper-2);border:1px solid var(--line);border-radius:var(--radius);
  overflow:hidden;box-shadow:var(--shadow-s);transition:transform .4s var(--ease),box-shadow .4s var(--ease);
  display:flex;flex-direction:column}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow-m)}
.card__media{position:relative;aspect-ratio:4/3;overflow:hidden}
.card__media img{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease)}
.card:hover .card__media img{transform:scale(1.05)}
.card__tag{position:absolute;top:.85rem;left:.85rem;background:rgba(33,28,22,.78);color:#fdf7ee;
  font-size:.72rem;font-weight:600;letter-spacing:.06em;padding:.32rem .7rem;border-radius:var(--radius-pill);
  backdrop-filter:blur(4px)}
.card__body{padding:1.5rem 1.6rem 1.7rem;display:flex;flex-direction:column;flex:1}
.card__body h3{font-size:1.7rem;font-weight:600}
.card__addr{font-size:.86rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;
  color:var(--clay);margin-top:.35rem}
.card__body p{color:var(--ink-soft);font-size:1.04rem;margin-top:.7rem;flex:1}
.card__foot{margin-top:1.3rem;display:flex;align-items:center;justify-content:space-between;gap:.6rem}
.badge{font-size:.78rem;color:var(--ink-soft);display:inline-flex;align-items:center;gap:.35rem}
.badge .dot{width:7px;height:7px;border-radius:50%;background:var(--gold)}
@media(max-width:860px){.house-grid{grid-template-columns:1fr;max-width:460px;margin-inline:auto}}

/* ── Ways to stay (the funnel) ─────────────────────────────────────────── */
.ways-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.4rem;margin-top:3.2rem}
.way{position:relative;background:var(--paper-2);border:1px solid var(--line);border-radius:var(--radius);
  padding:1.9rem 2rem 1.7rem;display:flex;flex-direction:column;gap:.55rem;overflow:hidden;
  transition:transform .35s var(--ease),box-shadow .35s var(--ease),border-color .35s}
.way::before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--wine);
  transform:scaleY(0);transform-origin:top;transition:transform .4s var(--ease)}
.way:hover{transform:translateY(-4px);box-shadow:var(--shadow-m);border-color:var(--line-soft)}
.way:hover::before{transform:scaleY(1)}
.way__k{font-size:.76rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--clay)}
.way h3{font-size:1.55rem;font-weight:500}
.way p{color:var(--ink-soft);font-size:1.05rem}
.way a{margin-top:.6rem}
.way--featured{background:linear-gradient(160deg,#2c211a,#3c2c20);color:#f5ece0;border-color:transparent}
.way--featured .way__k{color:var(--gold)}
.way--featured p{color:#e3d6c6}
.way--featured .txtlink{color:#f2c79a;border-color:transparent}
.way--featured .txtlink:hover{border-color:#f2c79a}
@media(max-width:760px){.ways-grid{grid-template-columns:1fr}}

/* ── Place / region ────────────────────────────────────────────────────── */
.place{background:#efe7d8}
.place__grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(2rem,5vw,4.5rem);align-items:center}
.place__media{position:relative}
.place__media img{border-radius:var(--radius);box-shadow:var(--shadow-m);aspect-ratio:4/5;object-fit:cover;width:100%}
.place__media figcaption{font-size:.8rem;color:var(--ink-soft);margin-top:.7rem;text-align:center;font-style:italic}
.place h2{font-size:clamp(2rem,3.8vw,3.1rem)}
.place__lead{font-size:1.22rem;margin-top:1.1rem;color:var(--ink)}
.facts{margin-top:1.8rem;display:flex;flex-direction:column;gap:1.15rem}
.fact{display:flex;gap:1rem;align-items:flex-start}
.fact .fi{flex:none;width:2.6rem;height:2.6rem;border-radius:50%;background:#fff;border:1px solid var(--line);
  display:grid;place-items:center;font-family:var(--serif);font-weight:600;color:var(--wine);font-size:1.15rem}
.fact h4{margin:0 0 .15rem;font-size:1.1rem;font-weight:700;font-family:var(--sans)}
.fact p{color:var(--ink-soft);font-size:1.02rem}
@media(max-width:840px){.place__grid{grid-template-columns:1fr}.place__media{order:-1;max-width:440px}}

/* ── Contact / enquiry ─────────────────────────────────────────────────── */
.contact{background:var(--ink);color:#f3eadd}
.contact .eyebrow{color:var(--gold)}
.contact h2{color:#fbf3e7;font-size:clamp(2rem,4vw,3.2rem)}
.contact__grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(2rem,5vw,4.5rem);margin-top:1rem}
.contact__intro p{color:#d9cab7;margin-top:1.1rem;font-size:1.12rem;max-width:40ch}
.contact__alt{margin-top:2rem;padding-top:1.5rem;border-top:1px solid rgba(255,255,255,.16)}
.contact__alt b{display:block;font-family:var(--serif);font-size:1.2rem;color:#fbf3e7;margin-bottom:.6rem}
.bk{display:inline-flex;gap:.5rem;flex-wrap:wrap}
.bk a{font-size:.92rem;color:#e9dccb;border:1px solid rgba(255,255,255,.28);border-radius:var(--radius-pill);
  padding:.45rem .95rem;transition:.2s}
.bk a:hover{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.5)}

.form{background:#fbf8f1;border-radius:var(--radius);padding:clamp(1.6rem,3vw,2.4rem);box-shadow:var(--shadow-m);color:var(--ink)}
.field{margin-bottom:1.15rem}
.field label{display:block;font-weight:700;font-size:.95rem;margin-bottom:.45rem}
.field input,.field select,.field textarea{width:100%;font:inherit;font-size:1.05rem;padding:.85rem 1rem;
  background:#fff;border:1.5px solid var(--line);border-radius:10px;color:var(--ink);transition:border-color .2s,box-shadow .2s}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--wine);
  box-shadow:0 0 0 3px rgba(124,43,39,.12)}
.field textarea{resize:vertical;min-height:96px}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.choices{display:flex;flex-wrap:wrap;gap:.55rem}
.choice{position:relative}
.choice input{position:absolute;opacity:0;inset:0;cursor:pointer}
.choice span{display:block;padding:.6rem 1rem;border:1.5px solid var(--line);border-radius:var(--radius-pill);
  font-size:.95rem;font-weight:600;color:var(--ink-soft);transition:.2s}
.choice input:checked+span{background:var(--wine);border-color:var(--wine);color:#fff}
.choice input:focus-visible+span{outline:3px solid var(--clay);outline-offset:2px}
.form .btn--primary{width:100%;justify-content:center;margin-top:.5rem}
.form__note{font-size:.82rem;color:var(--ink-soft);margin-top:.9rem;text-align:center}
.form__ok{background:#edf3ea;border:1px solid #cde0c5;color:#2f5226;border-radius:10px;padding:1rem;
  font-weight:600;margin-top:1rem;display:none}
.form__ok.show{display:block}
@media(max-width:820px){.contact__grid{grid-template-columns:1fr}.row2{grid-template-columns:1fr}}

/* ── Footer ────────────────────────────────────────────────────────────── */
.foot{background:#171310;color:#b6a896;padding-block:3rem 2.4rem;font-size:.95rem}
.foot__top{display:flex;flex-wrap:wrap;justify-content:space-between;gap:1.5rem;align-items:flex-start}
.foot b{font-family:var(--serif);color:#f1e7d8;font-size:1.45rem;font-weight:600}
.foot__top span{display:block;margin-top:.3rem;letter-spacing:.04em}
.foot__cols{display:flex;gap:3rem;flex-wrap:wrap}
.foot__cols h5{color:#e3d6c4;font-size:.8rem;letter-spacing:.14em;text-transform:uppercase;margin:0 0 .6rem;font-weight:700}
.foot__cols a,.foot__cols p{color:#b6a896;margin:.2rem 0}
.foot__cols a:hover{color:#f1e7d8}
.foot__bar{margin-top:2.4rem;padding-top:1.4rem;border-top:1px solid rgba(255,255,255,.1);
  display:flex;flex-wrap:wrap;gap:.5rem 1.5rem;justify-content:space-between;font-size:.82rem;color:#8c8071}
.poc{display:inline-flex;align-items:center;gap:.45rem}
.poc .dot{width:7px;height:7px;border-radius:50%;background:var(--gold)}
.foot__by{color:#cdbfac;border-bottom:1px solid rgba(255,255,255,.28);transition:color .2s,border-color .2s}
.foot__by:hover{color:#f1e7d8;border-color:#f1e7d8}

/* ── Scroll reveal (progressive: visible by default, hidden only with JS) ── */
.reveal{transition:opacity .8s var(--ease),transform .8s var(--ease)}
html.js .reveal{opacity:0;transform:translateY(26px)}
html.js .reveal.in{opacity:1;transform:none}
.reveal.s2{transition-delay:.1s}.reveal.s3{transition-delay:.2s}.reveal.s4{transition-delay:.3s}

@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto!important}
  .rise,.reveal{opacity:1;transform:none}
  .hero__img{transform:none}
}
