/* Niky — "Resta tra noi". Bespoke, warm, intimate editorial. NOT the network template.
   Concept: the secret girlfriend. Cream + cognac + candlelight gold, soft Fraunces display. */
:root{
  --bg:#f7efe6;        /* warm ivory */
  --bg2:#efe2d4;       /* soft beige */
  --panel:#23181a;     /* deep warm near-black (the "secret" panel) */
  --ink:#2c211c;       /* warm brown text */
  --muted:#897567;     /* taupe */
  --line:#e2d3c2;
  --accent:#b5563c;    /* cognac / terracotta */
  --accent-d:#974327;
  --gold:#c39a4e;      /* candlelight */
  --blush:#e9c7b8;
  --max:1180px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--ink);font-family:Inter,system-ui,sans-serif;
  font-size:17px;line-height:1.65;-webkit-font-smoothing:antialiased;overflow-x:hidden}
.serif{font-family:"Fraunces",Georgia,serif}
.script{font-family:"Dancing Script",cursive}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
.wrap{max-width:var(--max);margin:0 auto;padding:0 26px}
.eyebrow{font-size:12.5px;letter-spacing:.28em;text-transform:uppercase;color:var(--accent);font-weight:600}
h1,h2,h3{font-family:"Fraunces",Georgia,serif;font-weight:500;line-height:1.06;letter-spacing:-.01em}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:9px;font-weight:600;font-size:15px;
  padding:15px 30px;border-radius:2px;transition:.22s;cursor:pointer;border:1px solid transparent;white-space:nowrap}
.btn-fill{background:var(--accent);color:#fff;box-shadow:0 10px 30px -12px rgba(151,67,39,.6)}
.btn-fill:hover{background:var(--accent-d);transform:translateY(-2px)}
.btn-ghost{border-color:currentColor;color:var(--ink)}
.btn-ghost:hover{background:var(--ink);color:var(--bg)}
.btn-light{border:1px solid rgba(255,255,255,.5);color:#fff}
.btn-light:hover{background:#fff;color:var(--panel)}

/* 18+ gate */
#gate{position:fixed;inset:0;z-index:120;background:#1a1113;display:flex;align-items:center;justify-content:center;padding:24px}
#gate .box{max-width:430px;text-align:center;color:#f3e6da}
#gate .g{font-size:74px;line-height:1;color:#fff;margin-bottom:8px}
#gate p{color:#c5ad9e;margin:14px 0 26px;font-size:15px}
#gate .row{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}

/* nav */
.nav{position:sticky;top:0;z-index:60;background:rgba(247,239,230,.86);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.nav .wrap{display:flex;align-items:center;justify-content:space-between;height:70px}
.nav .logo{font-size:30px;color:var(--ink)}
.nav .btn{padding:11px 22px;font-size:14px}

/* hero */
.hero{position:relative;min-height:94vh;display:flex;align-items:flex-end;color:#fff;overflow:hidden}
.hero::before{content:"";position:absolute;inset:-2%;z-index:0;background:url(img/hero.jpg) center 22%/cover;
  background-image:image-set(url(img/hero.webp) type("image/webp"), url(img/hero.jpg) type("image/jpeg"));
  animation:kenburns 24s ease-in-out infinite alternate;will-change:transform}
.hero::after{content:"";position:absolute;inset:0;z-index:1;
  background:linear-gradient(180deg,rgba(26,17,19,.15) 0%,rgba(26,17,19,.05) 35%,rgba(26,17,19,.78) 100%)}
.hero .wrap{position:relative;z-index:2}
.hero .scrollcue{z-index:2}
@keyframes kenburns{from{transform:scale(1)}to{transform:scale(1.1)}}
@media(prefers-reduced-motion:reduce){.hero::before{animation:none}}
.hero .wrap{padding-bottom:64px;padding-top:90px}
.hero .eyebrow{color:var(--blush)}
.hero h1{font-size:clamp(44px,7.4vw,92px);font-weight:400;margin:16px 0 0;max-width:14ch;text-shadow:0 2px 30px rgba(0,0,0,.35)}
.hero .lead{max-width:46ch;margin:22px 0 30px;font-size:18.5px;color:#f0e4da}
.hero .cta-row{display:flex;align-items:center;gap:20px;flex-wrap:wrap}
.scrollcue{position:absolute;left:50%;bottom:22px;transform:translateX(-50%);color:#f0e4da;font-size:12px;letter-spacing:.2em;text-transform:uppercase;opacity:.8;animation:bob 2.4s ease-in-out infinite}
@keyframes bob{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(7px)}}

/* manifesto */
.manifesto{padding:110px 0;text-align:center}
.manifesto .pull{font-size:clamp(28px,4.6vw,50px);font-weight:400;max-width:18ch;margin:0 auto;line-height:1.16}
.manifesto .pull em{font-style:italic;color:var(--accent)}
.manifesto p{max-width:54ch;margin:30px auto 0;color:var(--muted);font-size:18px}

/* intimacy alternating blocks */
.blocks{padding:30px 0 70px}
.block{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;padding:46px 0}
.block:nth-child(even) .b-txt{order:2}
.block .b-img{position:relative}
.block .b-img img{width:100%;aspect-ratio:4/5;object-fit:cover;border-radius:3px;box-shadow:0 30px 60px -30px rgba(44,33,28,.5)}
.block .b-img::after{content:"";position:absolute;inset:0;border:1px solid rgba(255,255,255,.4);margin:14px;border-radius:2px;pointer-events:none}
.block h2{font-size:clamp(26px,3.4vw,38px);font-style:italic;font-weight:400}
.block p{margin-top:16px;color:var(--muted);font-size:17.5px;max-width:42ch}
.block .num{font-family:"Fraunces",serif;font-size:15px;color:var(--gold);letter-spacing:.1em;margin-bottom:10px}

/* gallery — editorial varied, not a uniform grid */
.gal-head{text-align:center;padding:40px 0 8px}
.gal-head h2{font-size:clamp(30px,4.4vw,48px);margin:10px 0 6px;font-weight:400}
.gal-head p{color:var(--muted)}
.gallery{columns:3;column-gap:16px;padding:34px 0 80px}
.gallery a{display:block;margin:0 0 16px;position:relative;break-inside:avoid;border-radius:3px;overflow:hidden}
.gallery img{width:100%;transition:.5s;filter:saturate(.96)}
.gallery a::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 60%,rgba(35,24,26,.35));opacity:0;transition:.4s}
.gallery a:hover img{transform:scale(1.04)}
.gallery a:hover::after{opacity:1}

/* secret panel (discretion) */
.secret{background:var(--panel);color:#f1e3d7;padding:104px 0;text-align:center;position:relative}
.secret::before{content:"";position:absolute;inset:0;background:radial-gradient(700px 320px at 50% 0,rgba(195,154,78,.16),transparent 70%)}
.secret .wrap{position:relative}
.secret .lock{font-size:30px;color:var(--gold)}
.secret h2{font-size:clamp(30px,4.6vw,52px);margin:14px auto 0;font-weight:400;max-width:16ch}
.secret p{max-width:50ch;margin:24px auto 0;color:#cdb6a6;font-size:18px}

/* experience cards */
.exp{padding:104px 0}
.exp .head{text-align:center;margin-bottom:50px}
.exp .head h2{font-size:clamp(30px,4.4vw,48px);font-weight:400;margin-top:10px}
.exp .grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.card{background:#fff;border:1px solid var(--line);border-radius:4px;padding:30px 26px;transition:.25s}
.card:hover{transform:translateY(-5px);box-shadow:0 24px 50px -28px rgba(44,33,28,.45);border-color:var(--blush)}
.card .k{font-family:"Fraunces",serif;font-size:14px;color:var(--gold);letter-spacing:.08em}
.card h3{font-size:23px;margin:8px 0 12px;font-weight:500;font-style:italic}
.card p{color:var(--muted);font-size:15.5px}

/* testimonials */
.tst{background:var(--bg2);padding:100px 0;text-align:center}
.tst .eyebrow{display:block;margin-bottom:40px}
.tst .grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.quote{background:var(--bg);border:1px solid var(--line);border-radius:4px;padding:32px 28px;text-align:left}
.quote .mark{font-family:"Fraunces",serif;font-size:54px;line-height:.6;color:var(--blush)}
.quote p{font-size:18px;font-style:italic;font-family:"Fraunces",serif;font-weight:400;margin:6px 0 16px}
.quote .who{font-size:13px;color:var(--muted);letter-spacing:.04em}

/* cta band */
.band{padding:120px 0;text-align:center;
  background:linear-gradient(180deg,var(--bg),var(--bg2))}
.band h2{font-size:clamp(36px,6vw,72px);font-weight:400}
.band p{color:var(--muted);font-size:19px;margin:18px auto 30px;max-width:40ch}

/* footer */
footer{background:var(--panel);color:#b39e90;text-align:center;padding:40px 0;font-size:13.5px;letter-spacing:.04em}
footer .logo{font-family:"Dancing Script",cursive;font-size:26px;color:#f1e3d7;display:block;margin-bottom:8px}

/* reveal on scroll */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .8s ease,transform .8s ease}
.reveal.in{opacity:1;transform:none}

/* ---- mobile ---- */
@media(max-width:860px){
  body{font-size:16px}
  .hero{min-height:88vh;background-position:center 18%}
  .block{grid-template-columns:1fr;gap:24px;padding:30px 0}
  .block:nth-child(even) .b-txt{order:0}
  .block .b-img{max-width:440px;margin:0 auto}
  .gallery{columns:2;column-gap:12px}
  .gallery a{margin-bottom:12px}
  .exp .grid{grid-template-columns:1fr 1fr;gap:12px}
  .tst .grid{grid-template-columns:1fr}
  .manifesto,.secret,.exp,.tst,.band{padding:74px 0}
  .nav .logo{font-size:26px}
}
@media(max-width:460px){
  .gallery{columns:1}
  .exp .grid{grid-template-columns:1fr}
  .hero .cta-row{flex-direction:column;align-items:stretch}
  .hero .cta-row .btn{justify-content:center}
}

/* ---- richer sections (copy v2) ---- */
.narrow{max-width:768px}
.navlinks{display:flex;align-items:center;gap:28px}
.navlinks a:not(.btn){font-size:14.5px;color:var(--muted);font-weight:500;transition:.15s}
.navlinks a:not(.btn):hover{color:var(--accent)}
@media(max-width:760px){.navlinks a:not(.btn){display:none}}

.passage{padding:24px 0 56px;text-align:center}
.passage .big,.evening .big{font-size:clamp(25px,3.9vw,40px);font-weight:400;line-height:1.2;margin:14px auto 20px;max-width:22ch}
.passage .big em,.evening .big em{font-style:italic;color:var(--accent)}
.passage p,.evening p{max-width:55ch;margin:0 auto;color:var(--muted);font-size:18px}
.evening{background:var(--bg2);padding:90px 0;text-align:center;margin:24px 0}
.evening .eyebrow{color:var(--accent)}

.faq{padding:96px 0}
.faq .head{text-align:center;margin-bottom:40px}
.faq .head h2{font-size:clamp(28px,4vw,44px);font-weight:400;margin-top:10px}
.faq details{border-bottom:1px solid var(--line)}
.faq summary{cursor:pointer;list-style:none;font-family:"Fraunces",serif;font-size:21px;padding:20px 38px 20px 0;position:relative;font-weight:500;font-style:italic}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";position:absolute;right:4px;top:18px;color:var(--accent);font-size:26px;line-height:1;transition:.2s}
.faq details[open] summary::after{content:"\2013"}
.faq details p{color:var(--muted);padding:0 0 22px;font-size:17px;max-width:62ch}

footer .wrap{display:flex;flex-direction:column;align-items:center}
footer .fnav{display:flex;gap:24px;justify-content:center;flex-wrap:wrap;margin:12px 0 16px}
footer .fnav a{color:#b39e90;font-size:14px;transition:.15s}
footer .fnav a:hover{color:var(--gold)}

/* story page hero */
.phero{padding:150px 0 64px;text-align:center;background:linear-gradient(180deg,var(--bg2),var(--bg))}
.phero .eyebrow{color:var(--accent)}
.phero h1{font-size:clamp(40px,6.4vw,80px);font-weight:400;margin-top:14px;line-height:1.04}
.phero .lead{max-width:54ch;margin:24px auto 0;color:var(--muted);font-size:19px}

/* network interlinking (footer) */
.netrow{margin:2px 0 16px;color:#8a766a;font-size:13px;line-height:2}
.netrow .lbl{color:#6f5d52;letter-spacing:.04em;margin-right:8px;text-transform:uppercase;font-size:11px}
.netrow a{color:#caa873;transition:.15s}
.netrow a:hover{color:var(--gold)}
