/* =========================================================
   Trova il tuo colore — Mariangela
   Moodboard: "Almanacco ciclico dipinto a mano"
   ========================================================= */

:root{
  /* palette */
  --cream:        #F5F0E3;
  --cream-2:      #EDE6D3;
  --card:         #FCFAF2;   /* bianco caldo tinto, non #fff puro */
  --ink:          #2A2B1C;
  --ink-soft:     #4A4B36;
  --green-deep:   #383E20;
  --green:        #5E6533;
  --green-soft:   #7C8447;
  --action:       #A8492A;   /* terracotta scuro: cream text passa AA */
  --action-hover: #BD5A33;
  --terracotta:   #BD5A33;
  --plum:         #6E4A66;
  --ochre:        #C99B3F;
  --ochre-bright: #DBB05A;   /* testo piccolo su fondo scuro: AA */

  /* phase colors (ruota del ciclo) */
  --phase-1: #6E4A66; /* prugna */
  --phase-2: #6E7A3E; /* verde */
  --phase-3: #BD5A33; /* terracotta */
  --phase-4: #C99B3F; /* senape */

  /* type */
  --font-display: "Young Serif", Georgia, serif;
  --font-body: "Hanken Grotesk", system-ui, -apple-system, sans-serif;
  --font-script: "Caveat", cursive;

  /* spacing / radius */
  --wrap: 1120px;
  --radius: 18px;
  --radius-lg: 30px;
  --shadow: 0 18px 50px -28px rgba(40,40,20,0.55);
}

/* ---------- reset ---------- */
*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  margin:0;
  font-family:var(--font-body);
  font-size:17px;
  line-height:1.7;
  color:var(--ink);
  background:var(--cream);
  overflow-x:hidden;
}
img{ max-width:100%; height:auto; display:block; }
a{ color:inherit; }
h1,h2,h3{ font-family:var(--font-display); font-weight:400; line-height:1.1; margin:0; }
p{ margin:0; }
ul,ol{ margin:0; padding:0; list-style:none; }

/* paper texture */
body::before{
  content:"";
  position:fixed; inset:0;
  pointer-events:none; z-index:9999;
  opacity:0.05;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

.wrap{ width:100%; max-width:var(--wrap); margin:0 auto; padding:0 22px; }
.narrow{ max-width:760px; }

.skip-link{
  position:absolute; left:-999px; top:0; z-index:200;
  background:var(--ink); color:var(--cream); padding:10px 16px; border-radius:0 0 10px 0;
}
.skip-link:focus{ left:0; }

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

/* ---------- buttons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center;
  min-height:48px; padding:13px 26px;
  font-family:var(--font-body); font-weight:600; font-size:1rem;
  text-decoration:none; border-radius:999px;
  transition:transform .2s ease, background-color .2s ease, color .2s ease;
}
.btn-solid{ background:var(--action); color:var(--cream); }
.btn-solid:hover{ background:var(--action-hover); transform:translateY(-2px); }
.btn-ghost{ background:transparent; color:var(--cream); border:1.5px solid rgba(245,240,227,.55); }
.btn-ghost:hover{ background:rgba(245,240,227,.12); transform:translateY(-2px); }
.btn-pill{ background:var(--action); color:var(--cream); min-height:44px; padding:10px 22px; }
.btn-pill:hover{ background:var(--action-hover); }

/* ---------- spiral animation ---------- */
.spiral-spin{ animation:spin 90s linear infinite; transform-origin:center; }
@keyframes spin{ to{ transform:rotate(360deg); } }

/* ---------- header ---------- */
.site-header{
  position:sticky; top:0; z-index:100;
  background:var(--cream);
  border-bottom:1px solid var(--cream-2);
}
.header-inner{ display:flex; align-items:center; justify-content:space-between; min-height:66px; gap:16px; }
.brand{ display:inline-flex; align-items:center; gap:10px; text-decoration:none; color:var(--ink); }
.brand-mark{ width:30px; height:30px; color:var(--action); flex:0 0 auto; }
.brand-text{ font-family:var(--font-display); font-size:1.18rem; line-height:1; }

.nav-desktop{ display:none; }

.nav-toggle{
  display:inline-flex; flex-direction:column; justify-content:center; gap:5px;
  width:46px; height:46px; padding:11px; border:none; background:transparent; cursor:pointer;
}
.nav-toggle span{ height:2.5px; width:100%; background:var(--ink); border-radius:2px; transition:transform .3s ease, opacity .2s ease; }
body.menu-open .nav-toggle span:nth-child(1){ transform:translateY(7.5px) rotate(45deg); }
body.menu-open .nav-toggle span:nth-child(2){ opacity:0; }
body.menu-open .nav-toggle span:nth-child(3){ transform:translateY(-7.5px) rotate(-45deg); }

/* ---------- mobile drawer ---------- */
.nav-drawer{
  position:fixed; inset:0; z-index:99;
  background:var(--green-deep);
  display:flex; align-items:center; justify-content:center;
  opacity:0; visibility:hidden; transition:opacity .3s ease, visibility .3s ease;
}
.nav-drawer.is-open{ opacity:1; visibility:visible; }
.nav-drawer nav{ display:flex; flex-direction:column; align-items:center; gap:6px; }
.nav-drawer a{
  font-family:var(--font-display); font-size:1.7rem; color:var(--cream);
  text-decoration:none; padding:12px 18px; min-height:44px;
}
.nav-drawer a:hover{ color:var(--ochre); }
.nav-drawer .drawer-cta{
  margin-top:18px; font-family:var(--font-body); font-size:1rem;
  background:var(--action); color:var(--cream); border-radius:999px;
}
body.menu-open{ overflow:hidden; }

/* ---------- hero ---------- */
.hero{
  position:relative; overflow:hidden;
  background:
    radial-gradient(120% 90% at 75% 8%, #454d29 0%, var(--green-deep) 55%, #2f3419 100%);
  color:var(--cream);
  padding:78px 0 86px;
}
.hero-frond{
  position:absolute; top:-26px; left:-44px;
  width:300px; height:340px; color:#222814; opacity:.16; pointer-events:none;
}
.hero-spiral{
  position:absolute; right:-70px; top:32px;
  width:330px; height:330px; color:rgba(201,155,63,.34); pointer-events:none;
}
.hero-inner{ position:relative; z-index:2; max-width:840px; }
.hero-eyebrow{
  font-size:.92rem; letter-spacing:.02em; color:var(--ochre-bright);
  margin-bottom:18px; font-weight:600;
}
.hero h1{
  font-size:clamp(2.7rem, 11vw, 5rem);
  letter-spacing:-.01em; margin-bottom:24px;
}
.hero h1 .line{ display:block; }
.hero h1 .accent-script{
  font-family:var(--font-script); font-size:1.18em; color:var(--ochre); line-height:.9;
}
.hero-sub{ font-size:1.18rem; max-width:560px; color:#ECE6D6; margin-bottom:34px; }
.hero-actions{ display:flex; flex-wrap:wrap; gap:14px; }

/* ---------- generic sections ---------- */
.section{ position:relative; padding:74px 0; overflow:hidden; }
.section-cream{ background:var(--cream); color:var(--ink); }
.section-deep{ background:var(--green-deep); color:var(--cream); }
.section-olive{ background:var(--green); color:var(--cream); }

.section-title{ font-size:clamp(2rem, 6vw, 3.1rem); margin-bottom:18px; color:var(--ink); }
.section-title.light{ color:var(--cream); }
.lead{ font-size:1.15rem; color:var(--ink-soft); max-width:620px; }
.section-deep .lead, .section-olive .lead{ color:#E6E0D0; }

/* ---------- per chi è ---------- */
.recognise{ margin:30px 0 26px; display:grid; gap:16px; }
.recognise li{
  display:flex; gap:14px; align-items:flex-start;
  font-size:1.12rem; color:var(--ink);
  background:var(--card); border:1px solid var(--cream-2);
  padding:16px 18px; border-radius:var(--radius);
}
.recognise .dot{
  flex:0 0 auto; width:12px; height:12px; margin-top:8px; border-radius:50%;
  background:var(--terracotta);
}
.recognise-close{
  font-family:var(--font-display); font-size:1.45rem; color:var(--action); line-height:1.3;
}

/* ---------- cos'è ---------- */
.corner-spiral{
  position:absolute; right:-80px; bottom:-80px;
  width:300px; height:300px; color:rgba(245,240,227,.08); pointer-events:none;
}
.cosa-grid{ display:grid; gap:18px; margin-top:6px; position:relative; z-index:2; }
.cosa-text{ font-size:1.18rem; color:#ECE6D6; }
.pull-quote{
  position:relative; z-index:2;
  margin-top:34px; font-family:var(--font-display); font-size:clamp(1.5rem,4.5vw,2.1rem);
  line-height:1.3; color:var(--ochre); max-width:680px;
}

/* ---------- percorso ---------- */
.percorso-head{ max-width:660px; margin-bottom:42px; }
.percorso-layout{ display:grid; gap:40px; align-items:start; }
.cycle{ position:relative; width:min(300px,78vw); aspect-ratio:1; margin:0 auto; }
.cycle-wheel{
  position:absolute; inset:0; border-radius:50%;
  background:conic-gradient(
    var(--phase-1) 0 25%,
    var(--phase-2) 25% 50%,
    var(--phase-3) 50% 75%,
    var(--phase-4) 75% 100%);
  -webkit-mask:radial-gradient(circle, transparent 0 32%, #000 33%);
          mask:radial-gradient(circle, transparent 0 32%, #000 33%);
  box-shadow:var(--shadow);
}
.cycle-spiral{
  position:absolute; inset:0; margin:auto; width:46%; height:46%; color:var(--green-deep);
}
.steps{ display:grid; gap:20px; }
.step{
  background:var(--card); border:1px solid var(--cream-2); border-radius:var(--radius);
  padding:22px 22px 24px;
}
.step-label{
  display:block; font-family:var(--font-script); font-size:1.55rem;
  color:var(--action); margin-bottom:6px; line-height:1;
}
.step p{ color:var(--ink-soft); font-size:1.05rem; }

/* ---------- chi sono ---------- */
.chisono-grid{ display:grid; gap:34px; align-items:center; }
.chisono-photo{ margin:0; }
.chisono-photo img{
  border-radius:var(--radius-lg); box-shadow:var(--shadow);
  width:100%; max-width:420px; margin:0 auto;
}
.chisono-text p{ margin-bottom:16px; color:#ECE6D6; font-size:1.1rem; }
.chisono-text .section-title{ margin-bottom:20px; }
.chisono-quote{
  font-family:var(--font-script); font-size:1.7rem; color:var(--ochre); line-height:1.2;
}

/* ---------- valori ---------- */
.values{ display:grid; gap:18px; margin:34px 0 30px; }
.value{
  background:var(--cream-2); border-radius:var(--radius); padding:24px 22px;
  border-bottom:4px solid var(--terracotta);
}
.value:nth-child(2){ border-bottom-color:var(--green-soft); }
.value:nth-child(3){ border-bottom-color:var(--plum); }
.value h3{ font-size:1.5rem; margin-bottom:6px; color:var(--ink); }
.value p{ color:var(--ink-soft); }
.mission{
  font-family:var(--font-display); font-size:clamp(1.4rem,4vw,1.95rem); line-height:1.35;
  color:var(--action); max-width:760px;
}

/* ---------- contatti ---------- */
.contact-spiral{
  position:absolute; left:-70px; top:-60px;
  width:260px; height:260px; color:rgba(201,155,63,.16); pointer-events:none;
}
.contact-inner{ position:relative; z-index:2; }
.contact-lead{ font-size:1.18rem; color:#ECE6D6; max-width:620px; margin-bottom:30px; }
.contact-card{
  background:rgba(245,240,227,.07); border:1px solid rgba(245,240,227,.2);
  border-radius:var(--radius-lg); padding:30px 26px; max-width:520px;
}
.contact-where{ color:var(--cream); font-size:1.08rem; margin-bottom:18px; }
.contact-social{ display:flex; align-items:center; gap:12px; margin-bottom:14px; }
.social-icon{ display:inline-flex; width:34px; height:34px; color:var(--ochre); }
.social-icon svg{ width:100%; height:100%; }
.social-handle{ font-size:1.18rem; font-weight:600; color:var(--cream); word-break:break-word; }
.contact-note{ color:#CFC9B8; font-size:1rem; }

/* ---------- footer ---------- */
.site-footer{ background:var(--ink); color:var(--cream); padding:38px 0; }
.footer-inner{ display:flex; flex-direction:column; gap:22px; }
.footer-brand{ display:flex; align-items:center; gap:14px; }
.footer-brand .brand-mark{ color:var(--ochre); width:38px; height:38px; }
.footer-name{ font-family:var(--font-display); font-size:1.25rem; }
.footer-tag{ color:#B9B4A2; font-size:.95rem; }
.footer-credit{ font-size:.85rem; color:#A7A291; }
.footer-credit a{ color:var(--ochre); }

/* ---------- reveal animation ---------- */
[data-reveal]{ opacity:0; transform:translateY(22px); transition:opacity .7s ease, transform .7s ease; }
[data-reveal].in{ opacity:1; transform:none; }

/* ===========================================================
   RESPONSIVE
   =========================================================== */
@media (min-width:768px){
  body{ font-size:18px; }
  .nav-toggle{ display:none; }
  .nav-drawer{ display:none; }
  .nav-desktop{
    display:flex; align-items:center; gap:30px;
  }
  .nav-desktop a{ text-decoration:none; color:var(--ink); font-weight:500; }
  .nav-desktop a:not(.btn){ font-size:1rem; padding:6px 2px; }
  .nav-desktop a:not(.btn):hover{ color:var(--action); }

  .section{ padding:96px 0; }
  .hero{ padding:104px 0 112px; }
  .hero-frond{ width:380px; height:430px; top:-40px; left:-30px; }
  .hero-spiral{ width:440px; height:440px; right:-60px; top:24px; }

  .cosa-grid{ grid-template-columns:1fr 1fr; gap:30px; }

  .percorso-layout{ grid-template-columns:340px 1fr; gap:56px; align-items:center; }
  .cycle{ margin:0; }

  .chisono-grid{ grid-template-columns:0.85fr 1fr; gap:54px; }
  .chisono-photo img{ max-width:none; }

  .values{ grid-template-columns:repeat(3,1fr); gap:22px; }
}

@media (min-width:1024px){
  .hero h1{ font-size:clamp(4rem,7vw,5.6rem); }
  .hero-sub{ font-size:1.28rem; }
}

@media (prefers-reduced-motion:reduce){
  *{ animation:none !important; scroll-behavior:auto !important; }
  [data-reveal]{ opacity:1; transform:none; transition:none; }
}
