/* =========================================================
   Magnolia Cooperativa Sociale — Stylesheet
   Palette: cream + sage green + warm terracotta accent
   Typography: Cormorant Garamond (display) + Manrope (body)
   ========================================================= */

:root{
  --bg:#F7F4ED;
  --bg-soft:#EFEAE0;
  --ink:#1F2A23;
  --ink-soft:#445048;
  --muted:#8A8F87;
  --line:#D9D2C4;
  --sage:#5F7A5C;
  --sage-deep:#3F5640;
  --sage-soft:#C8D2BD;
  --terra:#B85C3C;
  --terra-soft:#E8B59E;
  --cream:#FBF8F1;
  --shadow:0 1px 0 rgba(31,42,35,.06), 0 12px 40px -12px rgba(31,42,35,.18);
  --radius:14px;
  --radius-lg:22px;
  --maxw:1200px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:'Manrope', system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
  background:var(--bg);
  color:var(--ink);
  font-size:16px;
  line-height:1.6;
  font-weight:400;
  overflow-x:hidden;
}
img{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none;transition:color .25s ease}
a:hover{color:var(--terra)}
button{font:inherit;cursor:pointer;border:0;background:none}

::selection{background:var(--sage);color:var(--cream)}

/* ----- Layout ----- */
.container{max-width:var(--maxw);margin:0 auto;padding:0 24px}
section{padding:96px 0;position:relative}
@media (max-width:768px){
  section{padding:64px 0}
}

/* ----- Typography ----- */
h1,h2,h3,h4{
  font-family:'Cormorant Garamond', Georgia, serif;
  font-weight:500;
  letter-spacing:-.01em;
  color:var(--ink);
  line-height:1.08;
}
h1{font-size:clamp(2.5rem, 6vw, 4.5rem);font-weight:500}
h2{font-size:clamp(2rem, 4.2vw, 3.2rem)}
h3{font-size:clamp(1.4rem, 2.6vw, 1.85rem)}
h4{font-size:1.2rem;font-weight:600}

.eyebrow{
  font-family:'Manrope',sans-serif;
  text-transform:uppercase;
  letter-spacing:.22em;
  font-size:.75rem;
  font-weight:600;
  color:var(--sage-deep);
  display:inline-flex;align-items:center;gap:10px;
  margin-bottom:18px;
}
.eyebrow::before{content:"";width:32px;height:1px;background:var(--sage-deep);display:inline-block}

.lead{font-size:1.15rem;color:var(--ink-soft);max-width:640px;line-height:1.7}

/* ----- Header ----- */
.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(247,244,237,.85);
  backdrop-filter:saturate(160%) blur(14px);
  -webkit-backdrop-filter:saturate(160%) blur(14px);
  border-bottom:1px solid transparent;
  transition:border-color .3s ease, background .3s ease;
}
.site-header.scrolled{border-color:var(--line)}
.nav{
  display:flex;align-items:center;justify-content:space-between;
  padding:20px 0;
}
.brand{
  display:flex;align-items:center;gap:12px;
  font-family:'Cormorant Garamond',serif;
  font-size:1.65rem;font-weight:500;
  letter-spacing:-.01em;
}
.brand-mark{
  width:46px;height:46px;border-radius:12px;
  display:block;object-fit:cover;
  background:var(--cream);
  box-shadow:0 4px 14px -2px rgba(63,86,64,.25);
  border:1px solid var(--line);
}
.footer-logo{width:64px;height:64px;border-radius:14px;margin-bottom:18px;display:block}
.brand small{display:block;font-family:'Manrope',sans-serif;font-size:.65rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);font-weight:600;margin-top:-2px}

.nav-links{display:flex;align-items:center;gap:36px;list-style:none}
.nav-links a{
  font-size:.92rem;font-weight:500;color:var(--ink-soft);
  position:relative;padding:6px 0;
}
.nav-links a:hover, .nav-links a.active{color:var(--ink)}
.nav-links a.active::after{
  content:"";position:absolute;left:0;right:0;bottom:-2px;height:1px;background:var(--terra);
}

.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:14px 26px;border-radius:999px;
  font-weight:600;font-size:.92rem;letter-spacing:.01em;
  transition:transform .25s ease, background .25s ease, color .25s ease, box-shadow .25s ease;
  cursor:pointer;white-space:nowrap;
}
.btn-primary{background:var(--ink);color:var(--cream)}
.btn-primary:hover{background:var(--sage-deep);color:var(--cream);transform:translateY(-1px);box-shadow:0 10px 24px -10px rgba(63,86,64,.6)}
.btn-outline{background:transparent;color:var(--ink);border:1px solid var(--ink)}
.btn-outline:hover{background:var(--ink);color:var(--cream)}
.btn-terra{background:var(--terra);color:var(--cream)}
.btn-terra:hover{background:#9C4A2E;color:var(--cream);transform:translateY(-1px)}
.btn .arrow{transition:transform .25s ease}
.btn:hover .arrow{transform:translateX(3px)}

.menu-toggle{display:none;width:42px;height:42px;border-radius:50%;border:1px solid var(--line);align-items:center;justify-content:center}

@media (max-width:920px){
  .nav-links, .nav .btn{display:none}
  .menu-toggle{display:inline-flex}
  .nav-links.open{
    display:flex;flex-direction:column;gap:18px;
    position:fixed;inset:74px 0 0 0;background:var(--bg);
    padding:40px 24px;align-items:flex-start;
    border-top:1px solid var(--line);
  }
  .nav-links.open a{font-size:1.5rem;font-family:'Cormorant Garamond',serif}
}

/* ----- Hero ----- */
.hero{
  padding:90px 0 110px;
  position:relative;overflow:hidden;
}
.hero-grid{
  display:grid;grid-template-columns:1.15fr .85fr;gap:80px;align-items:center;
}
.hero-eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  background:var(--cream);border:1px solid var(--line);
  padding:8px 16px;border-radius:999px;
  font-size:.78rem;font-weight:600;color:var(--sage-deep);
  letter-spacing:.05em;
}
.hero h1{margin:24px 0 28px}
.hero h1 em{font-style:italic;color:var(--sage-deep);font-weight:400}
.hero-cta{display:flex;gap:14px;margin-top:36px;flex-wrap:wrap}
.hero-visual{
  position:relative;aspect-ratio:4/5;
  border-radius:var(--radius-lg);overflow:hidden;
  box-shadow:var(--shadow);
}
.hero-visual img{width:100%;height:100%;object-fit:cover}
.hero-badge{
  position:absolute;left:-30px;bottom:40px;
  background:var(--cream);padding:20px 22px;border-radius:var(--radius);
  display:flex;align-items:center;gap:14px;
  box-shadow:var(--shadow);max-width:260px;
}
.hero-badge .num{font-family:'Cormorant Garamond',serif;font-size:2.2rem;color:var(--sage-deep);font-weight:500;line-height:1}
.hero-badge .lbl{font-size:.78rem;color:var(--ink-soft);line-height:1.3}

@media (max-width:920px){
  .hero{padding:50px 0 80px}
  .hero-grid{grid-template-columns:1fr;gap:50px}
  .hero-badge{left:auto;right:20px;bottom:-30px}
}

/* ----- Stats ----- */
.stats{
  display:grid;grid-template-columns:repeat(4,1fr);
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
}
.stat{padding:48px 28px;border-right:1px solid var(--line)}
.stat:last-child{border-right:0}
.stat .n{font-family:'Cormorant Garamond',serif;font-size:3rem;color:var(--ink);font-weight:500;line-height:1}
.stat .l{font-size:.85rem;color:var(--ink-soft);margin-top:8px;letter-spacing:.02em}
@media (max-width:768px){
  .stats{grid-template-columns:repeat(2,1fr)}
  .stat{padding:32px 20px;border-bottom:1px solid var(--line)}
  .stat:nth-child(2){border-right:0}
  .stat:nth-child(3),.stat:nth-child(4){border-bottom:0}
}

/* ----- Section heading ----- */
.section-head{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:end;margin-bottom:60px}
.section-head h2{max-width:560px}
.section-head .lead{justify-self:start}
@media (max-width:820px){.section-head{grid-template-columns:1fr;gap:24px}}

/* ----- Services / Centri ----- */
.centri{display:grid;grid-template-columns:repeat(2,1fr);gap:28px}
.centro{
  background:var(--cream);border-radius:var(--radius-lg);overflow:hidden;
  border:1px solid var(--line);transition:transform .35s ease, box-shadow .35s ease;
  display:flex;flex-direction:column;
}
.centro:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.centro-img{aspect-ratio:16/10;overflow:hidden;background:var(--bg-soft)}
.centro-img img{width:100%;height:100%;object-fit:cover;transition:transform .8s ease}
.centro:hover .centro-img img{transform:scale(1.05)}
.centro-body{padding:32px 30px;flex:1;display:flex;flex-direction:column;gap:14px}
.centro-tag{
  display:inline-flex;align-items:center;gap:8px;
  font-size:.7rem;text-transform:uppercase;letter-spacing:.18em;font-weight:700;
  color:var(--terra);
}
.centro-tag .dot{width:8px;height:8px;border-radius:50%;background:var(--terra)}
.centro h3{margin-bottom:4px}
.centro .addr{font-size:.85rem;color:var(--muted);font-style:italic}
.centro p{color:var(--ink-soft);font-size:.95rem}
.centro .more{margin-top:auto;font-size:.85rem;font-weight:600;color:var(--ink);display:inline-flex;align-items:center;gap:8px}
.centro .more:hover{color:var(--terra)}

@media (max-width:768px){.centri{grid-template-columns:1fr}}

/* ----- Values ----- */
.values{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden}
.value{background:var(--cream);padding:42px 32px;display:flex;flex-direction:column;gap:14px;transition:background .3s ease}
.value:hover{background:var(--bg-soft)}
.value .ico{width:42px;height:42px;border-radius:50%;background:var(--sage-soft);color:var(--sage-deep);display:flex;align-items:center;justify-content:center}
.value h4{font-family:'Cormorant Garamond',serif;font-size:1.5rem;font-weight:500}
.value p{color:var(--ink-soft);font-size:.94rem}
@media (max-width:820px){.values{grid-template-columns:1fr}}

/* ----- Quote ----- */
.quote{
  background:var(--sage-deep);color:var(--cream);
  border-radius:var(--radius-lg);padding:80px 60px;
  display:grid;grid-template-columns:auto 1fr;gap:40px;align-items:center;
  position:relative;overflow:hidden;
}
.quote::after{content:"";position:absolute;right:-60px;bottom:-60px;width:240px;height:240px;border-radius:50%;background:rgba(255,255,255,.05)}
.quote .mark{font-family:'Cormorant Garamond',serif;font-size:6rem;line-height:.8;color:var(--terra-soft)}
.quote blockquote{font-family:'Cormorant Garamond',serif;font-size:clamp(1.5rem,3vw,2.2rem);font-weight:400;line-height:1.3;font-style:italic}
.quote cite{display:block;margin-top:20px;font-style:normal;font-family:'Manrope',sans-serif;font-size:.85rem;letter-spacing:.15em;text-transform:uppercase;color:var(--terra-soft)}
@media (max-width:768px){.quote{padding:50px 30px;grid-template-columns:1fr;gap:20px}}

/* ----- 5x1000 CTA banner ----- */
.cta-banner{
  background:var(--cream);border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:60px;display:grid;grid-template-columns:1.4fr 1fr;gap:48px;align-items:center;
  position:relative;overflow:hidden;
}
.cta-banner::before{
  content:"";position:absolute;left:0;top:0;bottom:0;width:6px;background:var(--terra);
}
.cta-banner h3{font-size:2rem;margin-bottom:14px}
.cta-banner .cf{
  background:var(--bg-soft);padding:24px 28px;border-radius:var(--radius);
  text-align:center;
}
.cta-banner .cf .lbl{font-size:.72rem;text-transform:uppercase;letter-spacing:.2em;color:var(--muted);font-weight:700}
.cta-banner .cf .val{font-family:'Cormorant Garamond',serif;font-size:1.8rem;font-weight:600;letter-spacing:.05em;color:var(--terra);margin-top:6px}
@media (max-width:820px){.cta-banner{padding:40px 28px;grid-template-columns:1fr}}

/* ----- Footer ----- */
.site-footer{
  background:var(--ink);color:var(--cream);
  padding:80px 0 32px;margin-top:80px;
}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:50px;margin-bottom:60px}
.site-footer h5{font-family:'Manrope',sans-serif;font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.2em;color:var(--terra-soft);margin-bottom:20px}
.site-footer p, .site-footer a{font-size:.92rem;color:rgba(251,248,241,.78);line-height:1.8}
.site-footer a:hover{color:var(--cream)}
.footer-brand{font-family:'Cormorant Garamond',serif;font-size:1.8rem;color:var(--cream);margin-bottom:18px;display:block}
.footer-list{list-style:none;display:flex;flex-direction:column;gap:10px}
.socials{display:flex;gap:12px;margin-top:22px}
.socials a{
  width:38px;height:38px;border:1px solid rgba(251,248,241,.2);border-radius:50%;
  display:flex;align-items:center;justify-content:center;color:var(--cream);
  transition:background .25s ease, border-color .25s ease;
}
.socials a:hover{background:var(--terra);border-color:var(--terra)}
.copyr{
  border-top:1px solid rgba(251,248,241,.12);padding-top:30px;
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:14px;
  font-size:.82rem;color:rgba(251,248,241,.55);
}
@media (max-width:820px){.footer-grid{grid-template-columns:1fr 1fr;gap:36px}}
@media (max-width:540px){.footer-grid{grid-template-columns:1fr}}

/* ----- Page hero (interna) ----- */
.page-hero{padding:80px 0 60px;border-bottom:1px solid var(--line)}
.page-hero .container{display:grid;grid-template-columns:1.2fr 1fr;gap:60px;align-items:end}
.page-hero h1{font-size:clamp(2.4rem,5vw,4rem)}
.page-hero .crumb{font-size:.8rem;color:var(--muted);letter-spacing:.1em;text-transform:uppercase;margin-bottom:20px}
@media (max-width:820px){.page-hero .container{grid-template-columns:1fr;gap:24px}}

/* ----- Content prose ----- */
.prose{max-width:760px;margin:0 auto}
.prose p{font-size:1.05rem;color:var(--ink-soft);margin-bottom:1.2em}
.prose h2{margin:2.4em 0 .6em}
.prose h3{margin:1.8em 0 .4em}
.prose ul{padding-left:1.2em;margin-bottom:1.2em}
.prose li{margin-bottom:.5em;color:var(--ink-soft)}

/* ----- Tables (5x1000 / trasparenza) ----- */
.table-wrap{overflow-x:auto;border:1px solid var(--line);border-radius:var(--radius-lg);background:var(--cream)}
table.docs{width:100%;border-collapse:collapse;font-size:.95rem;min-width:640px}
table.docs th, table.docs td{padding:18px 22px;text-align:left;border-bottom:1px solid var(--line);vertical-align:top}
table.docs th{background:var(--bg-soft);font-weight:600;font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-soft)}
table.docs tr:last-child td{border-bottom:0}
table.docs td.year{font-family:'Cormorant Garamond',serif;font-size:1.5rem;font-weight:500;color:var(--sage-deep);width:170px}
table.docs td.amount{font-weight:600;color:var(--ink)}
table.docs a{
  display:inline-flex;align-items:center;gap:8px;
  color:var(--terra);font-weight:600;font-size:.88rem;
  border-bottom:1px solid transparent;
}
table.docs a:hover{border-color:var(--terra)}

/* ----- Doc list (semplice) ----- */
.doc-list{list-style:none;display:flex;flex-direction:column;gap:14px;margin-top:30px}
.doc-list li{
  background:var(--cream);border:1px solid var(--line);border-radius:var(--radius);
  padding:22px 26px;display:flex;justify-content:space-between;align-items:center;gap:20px;
  transition:border-color .25s ease, transform .25s ease;
}
.doc-list li:hover{border-color:var(--sage);transform:translateX(2px)}
.doc-list .yr{font-family:'Cormorant Garamond',serif;font-size:1.5rem;font-weight:500;color:var(--sage-deep)}
.doc-list a.dl{
  font-size:.85rem;font-weight:600;color:var(--ink);display:inline-flex;align-items:center;gap:8px;
}
.doc-list a.dl:hover{color:var(--terra)}

/* ----- Contact ----- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:start}
.contact-card{background:var(--cream);border:1px solid var(--line);border-radius:var(--radius-lg);padding:40px}
.contact-card h3{margin-bottom:20px}
.contact-row{display:flex;gap:16px;padding:16px 0;border-bottom:1px solid var(--line)}
.contact-row:last-child{border:0}
.contact-row .ic{width:40px;height:40px;border-radius:50%;background:var(--sage-soft);color:var(--sage-deep);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.contact-row .lbl{font-size:.72rem;text-transform:uppercase;letter-spacing:.18em;color:var(--muted);font-weight:600}
.contact-row .val{font-size:1rem;color:var(--ink);margin-top:2px}
form.contact-form{display:flex;flex-direction:column;gap:18px}
form.contact-form label{font-size:.78rem;text-transform:uppercase;letter-spacing:.16em;color:var(--ink-soft);font-weight:600;margin-bottom:6px;display:block}
form.contact-form input, form.contact-form textarea{
  width:100%;padding:14px 16px;border:1px solid var(--line);border-radius:var(--radius);
  background:var(--cream);font:inherit;color:var(--ink);
  transition:border-color .25s ease, background .25s ease;
}
form.contact-form input:focus, form.contact-form textarea:focus{outline:0;border-color:var(--sage);background:#fff}
form.contact-form textarea{min-height:140px;resize:vertical}
@media (max-width:820px){.contact-grid{grid-template-columns:1fr;gap:36px}}

/* ----- Animations ----- */
@keyframes rise {from{opacity:0;transform:translateY(20px)} to{opacity:1;transform:translateY(0)}}
.reveal{opacity:0;transform:translateY(24px);transition:opacity .9s ease, transform .9s ease}
.reveal.in{opacity:1;transform:translateY(0)}

/* ----- Utility ----- */
.center{text-align:center}
.mt-l{margin-top:48px}
.mt-m{margin-top:24px}
.divider{height:1px;background:var(--line);margin:60px 0}
