/* ═══════════════════════════════════════════════════════════
   Easy Italia Hub — shared editorial stylesheet (eih.css)
   Used by the secondary pages (guide, community, legal, …).
   Same design language as the landing & journey pages.
   ═══════════════════════════════════════════════════════════ */
:root{
  --bg-deep:#fdfcf9;--bg-base:#f9f5f0;--bg-elevated:#ffffff;
  --surface:rgba(40,36,30,0.025);--surface-hover:rgba(40,36,30,0.052);
  --border:rgba(118,118,118,0.14);--border-bright:rgba(118,118,118,0.26);
  --taupe:#c4a882;--coral:#eb5939;
  --gold:#9a7d45;--gold-dim:rgba(154,125,69,0.13);
  --blue:#7d7058;--blue-deep:#665b46;--blue-glow:rgba(125,112,88,0.18);
  --green:#1f9d55;--green-dim:rgba(31,157,85,0.12);
  --ink:#161412;--fg:#1c1a17;--fg-secondary:#524c44;--fg-muted:#7d7568;
  --blur-amount:20px;
  --text-xs:.75rem;--text-sm:.875rem;--text-base:1rem;--text-lg:1.125rem;--text-xl:1.5rem;--text-2xl:2rem;--text-3xl:3rem;
  --sp-1:.5rem;--sp-2:1rem;--sp-3:1.5rem;--sp-4:2rem;--sp-5:3rem;--sp-6:4rem;
  --ease-enter:cubic-bezier(0.0,0.0,0.2,1);--ease-spring:cubic-bezier(0.16,1,0.3,1);
  --dur-micro:150ms;--dur-std:280ms;--dur-complex:420ms;
  --radius:16px;--radius-sm:10px;--radius-full:9999px;
}
@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}
*{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;scroll-behavior:smooth}
body{font-family:'Satoshi','Inter',system-ui,sans-serif;background:var(--bg-base);color:var(--fg);min-height:100vh;overflow-x:hidden;-webkit-font-smoothing:antialiased}
a{color:inherit}
.skip-link{position:absolute;top:-100%;left:var(--sp-2);padding:.5rem 1rem;border-radius:var(--radius-sm);background:var(--blue);color:#fff;font-size:var(--text-sm);font-weight:500;text-decoration:none;z-index:9999}
.skip-link:focus{top:var(--sp-1)}
.sr{position:absolute;width:1px;height:1px;padding:0;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* ── background wash + noise ── */
#bg{position:fixed;inset:0;z-index:0;pointer-events:none;background:radial-gradient(1100px 700px at 18% 12%,rgba(235,89,57,0.05),transparent 60%),radial-gradient(900px 600px at 85% 80%,rgba(154,125,69,0.06),transparent 60%),linear-gradient(180deg,#ffffff 0%,#f8f2e9 100%)}
#noise{position:fixed;inset:0;z-index:1;pointer-events:none;opacity:.035;mix-blend-mode:multiply;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='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}

/* ── custom cursor ── */
@media (pointer:fine){
  .cursor-dot,.cursor-ring{position:fixed;top:0;left:0;border-radius:50%;pointer-events:none;z-index:10000;transform:translate(-50%,-50%);will-change:transform}
  .cursor-dot{width:8px;height:8px;background:var(--taupe);mix-blend-mode:difference}
  .cursor-ring{width:40px;height:40px;border:1px solid var(--taupe);z-index:9999;transition:width var(--dur-std) var(--ease-spring),height var(--dur-std) var(--ease-spring),border-color var(--dur-std),background var(--dur-std)}
  .cursor-ring.hover{width:60px;height:60px;border-color:rgba(235,89,57,0.6);background:rgba(235,89,57,0.06)}
  .cursor-hidden{opacity:0}
  body.has-cursor{cursor:none}
  body.has-cursor a,body.has-cursor button,body.has-cursor [role="button"],body.has-cursor input{cursor:none}
}

/* ── preloader + wipe ── */
#preloader{position:fixed;inset:0;z-index:10001;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:1.1rem;background:var(--bg-base);transition:opacity .6s var(--ease-spring),visibility .6s}
#preloader.done{opacity:0;visibility:hidden;pointer-events:none}
html.returning #preloader{display:none}
#preloader .pre-logo{font-family:'Clash Grotesk',sans-serif;font-size:clamp(1.6rem,4vw,2.4rem);font-weight:600;letter-spacing:-.02em;color:var(--ink)}
#preloader .pre-logo em{font-style:normal;color:var(--taupe)}
#preloader .pre-bar{width:120px;height:2px;background:var(--border);overflow:hidden;border-radius:2px;position:relative}
#preloader .pre-bar::after{content:'';position:absolute;inset:0;background:var(--taupe);transform:translateX(-100%);animation:preBar 1.1s var(--ease-enter) .2s forwards}
@keyframes preBar{to{transform:translateX(0)}}
#wipe{position:fixed;inset:0;z-index:9998;background:var(--ink);opacity:0;visibility:hidden;pointer-events:none;transition:opacity .5s var(--ease-spring),visibility .5s}
#wipe.cover{opacity:1;visibility:visible}

/* ── NAV ── */
.site-nav{position:fixed;top:0;left:0;right:0;z-index:200;display:flex;align-items:center;justify-content:space-between;padding:var(--sp-2) var(--sp-5);background:rgba(255,255,255,0.82);backdrop-filter:blur(var(--blur-amount)) saturate(1.5);-webkit-backdrop-filter:blur(var(--blur-amount)) saturate(1.5);border-bottom:1px solid var(--border)}
.nav-logo{font-family:'Clash Grotesk',sans-serif;font-size:var(--text-lg);font-weight:600;color:var(--ink);display:flex;align-items:center;gap:.4rem;letter-spacing:-.01em;text-decoration:none}
.nav-logo .accent{color:var(--taupe)}
.nav-collapse{display:contents}
.nav-links{display:flex;gap:var(--sp-3);list-style:none}
.nav-links a{font-size:var(--text-sm);font-weight:400;color:var(--fg-muted);text-decoration:none;letter-spacing:.05em;transition:color var(--dur-micro);cursor:pointer}
.nav-links a:hover,.nav-links a.active{color:var(--ink)}
.nav-links a.active{font-weight:600;color:var(--gold)}
.nav-right{display:flex;align-items:center;gap:var(--sp-2)}
.nav-login{font-size:var(--text-sm);font-weight:400;color:var(--fg-secondary);text-decoration:none;cursor:pointer;background:none;border:none;font-family:inherit;transition:color var(--dur-micro)}
.nav-login:hover{color:var(--ink)}
.nav-cta{padding:.55rem 1.4rem;border-radius:var(--radius-full);font-size:var(--text-sm);font-weight:500;letter-spacing:.03em;color:#fff;text-decoration:none;border:1px solid rgba(125,112,88,0.35);cursor:pointer;background:linear-gradient(135deg,var(--blue-deep),var(--blue));transition:opacity var(--dur-micro),transform var(--dur-std) var(--ease-spring)}
.nav-cta:hover{opacity:.88;transform:translateY(-2px)}
.nav-mobile-extra{display:none}
.nav-toggle{display:none;flex-direction:column;justify-content:center;gap:5px;width:44px;height:44px;padding:0 10px;border:none;background:none;cursor:pointer;border-radius:var(--radius-sm)}
.nav-toggle span{display:block;height:2px;width:100%;border-radius:2px;background:var(--ink);transition:transform var(--dur-std) var(--ease-spring),opacity var(--dur-micro)}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.lang-switch{position:relative}
.lang-btn{display:inline-flex;align-items:center;gap:.35rem;padding:.4rem .6rem;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface);cursor:pointer;font-family:inherit;font-size:var(--text-sm);font-weight:500;color:var(--ink);min-height:38px}
.lang-btn:hover{background:var(--surface-hover)}
.lang-chevron{width:14px;height:14px;stroke:var(--fg-muted);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;transition:transform var(--dur-std) var(--ease-spring)}
.lang-btn[aria-expanded="true"] .lang-chevron{transform:rotate(180deg)}
.lang-menu{position:absolute;top:calc(100% + .4rem);right:0;z-index:210;min-width:160px;list-style:none;padding:.35rem;border-radius:var(--radius-sm);border:1px solid var(--border-bright);background:#ffffff;box-shadow:0 16px 40px rgba(20,30,48,.14);transform:translateY(-8px) scale(.97);transform-origin:top right;opacity:0;pointer-events:none;transition:transform var(--dur-std) var(--ease-spring),opacity var(--dur-micro)}
.lang-menu.open{transform:translateY(0) scale(1);opacity:1;pointer-events:auto}
.lang-menu button{display:flex;align-items:center;gap:.6rem;width:100%;padding:.55rem .7rem;border:none;background:none;cursor:pointer;font-family:inherit;font-size:var(--text-sm);color:var(--ink);text-align:left;border-radius:8px;min-height:40px}
.lang-menu button:hover{background:var(--surface-hover)}
.lang-menu button[aria-current="true"]{background:var(--gold-dim);font-weight:600}
.lang-menu button span{font-size:1.05rem}

/* ── PAGE shell ── */
main{position:relative;z-index:1}
.page{max-width:1060px;margin:0 auto;padding:calc(var(--sp-6) + 2.5rem) var(--sp-4) var(--sp-6)}
.page-wide{max-width:1320px}
.eyebrow{display:inline-flex;align-items:center;gap:.7rem;margin-bottom:1.1rem;font-size:.66rem;font-weight:500;letter-spacing:.3em;text-transform:uppercase;color:var(--gold)}
.eyebrow-line{width:32px;height:1px;background:var(--gold);opacity:.6}
.page h1{font-family:'Clash Grotesk',sans-serif;font-size:clamp(2.4rem,5.5vw,4.25rem);font-weight:600;line-height:1;letter-spacing:-.035em;color:var(--ink);margin-bottom:var(--sp-3)}
.page h1 em{font-style:normal;color:var(--taupe)}
.page .lead{font-size:var(--text-lg);line-height:1.7;color:var(--fg-secondary);font-weight:300;max-width:620px;margin-bottom:var(--sp-4)}
.page h2{font-family:'Clash Grotesk',sans-serif;font-size:var(--text-2xl);font-weight:600;letter-spacing:-.02em;color:var(--ink);margin:var(--sp-5) 0 var(--sp-2)}
.page h3{font-family:'Clash Grotesk',sans-serif;font-size:var(--text-lg);font-weight:600;color:var(--ink);margin:var(--sp-3) 0 .4rem}
.page p{font-size:var(--text-base);line-height:1.75;color:var(--fg-secondary);margin-bottom:var(--sp-2)}
.page ul,.page ol{color:var(--fg-secondary);line-height:1.7;margin:0 0 var(--sp-2) 1.2rem}
.page li{margin-bottom:.4rem}
.page a.inline{color:var(--gold);text-decoration:underline;text-underline-offset:2px}
.muted{color:var(--fg-muted);font-size:var(--text-sm)}
.draft-banner{display:flex;align-items:flex-start;gap:.6rem;background:var(--gold-dim);border:1px solid rgba(124,112,89,.25);border-radius:var(--radius-sm);padding:.8rem 1rem;font-size:var(--text-sm);color:var(--ink);margin-bottom:var(--sp-3)}
.soon{display:inline-block;font-size:.62rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--gold);background:var(--gold-dim);border:1px solid rgba(124,112,89,.25);padding:.2rem .6rem;border-radius:99px;margin-left:.5rem;vertical-align:middle}

/* cards grid for section pages */
.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1.1rem;margin-top:var(--sp-3)}
.icard{padding:1.4rem;border-radius:var(--radius);background:var(--bg-elevated);border:1px solid var(--border);transition:transform var(--dur-std) var(--ease-spring),box-shadow var(--dur-std)}
.icard:hover{transform:translateY(-4px);box-shadow:0 16px 40px rgba(20,30,48,.1)}
.icard .ic{font-size:1.5rem;margin-bottom:.6rem}
/* ── subtle animated "aurora" motion behind card icons (CSS-only, GPU-friendly) ── */
.icard .ic{position:relative;display:inline-flex;align-items:center;justify-content:center;width:2.6rem;height:2.6rem;border-radius:14px;overflow:hidden;isolation:isolate;line-height:1}
.icard .ic::before{content:"";position:absolute;z-index:-1;top:-60%;left:-60%;width:220%;height:220%;border-radius:inherit;background:radial-gradient(60% 60% at 30% 30%,rgba(183,171,152,0.30),transparent 70%),radial-gradient(55% 55% at 75% 65%,rgba(124,112,89,0.24),transparent 72%),radial-gradient(50% 50% at 60% 20%,rgba(31,157,85,0.18),transparent 70%);background-repeat:no-repeat;will-change:transform;transform:translate3d(0,0,0) scale(1) rotate(0deg);animation:icAurora 15s ease-in-out infinite alternate;pointer-events:none}
@keyframes icAurora{from{transform:translate3d(-6%,-4%,0) scale(1.05) rotate(-4deg)}to{transform:translate3d(6%,5%,0) scale(1.18) rotate(4deg)}}
/* gentle per-card tint variety, staying within the brand palette */
.card-grid .icard:nth-child(3n+2) .ic::before{background:radial-gradient(60% 60% at 35% 30%,rgba(235,89,57,0.22),transparent 70%),radial-gradient(55% 55% at 70% 70%,rgba(183,171,152,0.28),transparent 72%),radial-gradient(50% 50% at 60% 25%,rgba(124,112,89,0.20),transparent 70%);background-repeat:no-repeat}
.card-grid .icard:nth-child(3n+3) .ic::before{background:radial-gradient(60% 60% at 30% 35%,rgba(31,157,85,0.20),transparent 70%),radial-gradient(55% 55% at 72% 62%,rgba(124,112,89,0.26),transparent 72%),radial-gradient(50% 50% at 55% 22%,rgba(183,171,152,0.26),transparent 70%);background-repeat:no-repeat}
.card-grid .icard:nth-child(3n+2) .ic::before{animation-duration:13s}
.card-grid .icard:nth-child(3n+3) .ic::before{animation-duration:16s;animation-delay:-3s}
@media (prefers-reduced-motion:reduce){.icard .ic::before{animation:none;transform:translate3d(0,0,0) scale(1.12) rotate(0deg)}}
.icard h3{margin:0 0 .3rem;font-family:'Clash Grotesk',sans-serif;font-size:var(--text-lg);font-weight:600;color:var(--ink)}
.icard p{margin:0;font-size:var(--text-sm);line-height:1.6}

/* buttons */
.btn-primary{display:inline-flex;align-items:center;justify-content:center;gap:.45rem;padding:.8rem 1.75rem;border-radius:var(--radius-full);font-size:var(--text-sm);font-weight:500;letter-spacing:.02em;color:#fff;text-decoration:none;border:none;cursor:pointer;background:linear-gradient(135deg,var(--blue-deep),var(--blue));box-shadow:0 8px 28px var(--blue-glow);min-height:44px;transition:transform var(--dur-std) var(--ease-spring)}
.btn-primary:hover{transform:translateY(-3px)}
.btn-accent{background:linear-gradient(135deg,var(--coral),#ff7c5c);box-shadow:0 8px 28px rgba(235,89,57,.32)}
.btn-accent:hover{box-shadow:0 16px 44px rgba(235,89,57,.4)}
.btn-accent:focus-visible{outline-color:var(--coral)}
.btn-ghost{display:inline-flex;align-items:center;justify-content:center;gap:.45rem;padding:.8rem 1.75rem;border-radius:var(--radius-full);font-size:var(--text-sm);font-weight:400;color:var(--ink);text-decoration:none;border:1px solid var(--border-bright);cursor:pointer;min-height:44px;transition:background var(--dur-micro),transform var(--dur-std) var(--ease-spring)}
.btn-ghost:hover{background:var(--surface-hover);transform:translateY(-2px)}
.cta-row{display:flex;gap:.8rem;flex-wrap:wrap;margin-top:var(--sp-3)}

/* form (contatti) */
.form{display:flex;flex-direction:column;gap:var(--sp-2);max-width:520px;margin-top:var(--sp-3)}
.form label{font-size:var(--text-xs);color:var(--fg-secondary);font-weight:500;margin-bottom:.3rem;display:block}
.form input,.form textarea{width:100%;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:.7rem .9rem;font-size:var(--text-base);color:var(--ink);font-family:inherit;outline:none;min-height:44px}
.form input:focus,.form textarea:focus{border-color:rgba(125,112,88,.5)}
.form textarea{min-height:120px;resize:vertical}

/* ── FOOTER ── */
footer{position:relative;z-index:1;margin-top:var(--sp-6);border-top:1px solid var(--border);background:rgba(255,252,248,0.82);backdrop-filter:blur(12px)}
.footer-inner{max-width:1200px;margin:0 auto;padding:var(--sp-5) var(--sp-5) var(--sp-3);display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:var(--sp-4)}
.footer-tag{font-size:var(--text-sm);color:var(--fg-muted);line-height:1.6;font-weight:300;max-width:280px;margin-top:var(--sp-2)}
.footer-col h4{font-size:var(--text-xs);font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--ink);margin-bottom:var(--sp-2)}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:.65rem}
.footer-col a,.footer-col button{font-size:var(--text-sm);color:var(--fg-muted);text-decoration:none;font-weight:300;background:none;border:none;padding:0;font-family:inherit;cursor:pointer;text-align:left;transition:color var(--dur-micro)}
.footer-col a:hover,.footer-col button:hover{color:var(--ink)}
.footer-bottom{max-width:1200px;margin:0 auto;padding:var(--sp-2) var(--sp-5) var(--sp-3);border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:var(--sp-1)}
.footer-copy{font-size:var(--text-xs);color:var(--fg-muted);font-weight:300}
.footer-legal{display:flex;gap:var(--sp-2);flex-wrap:wrap}
.footer-legal a{font-size:var(--text-xs);color:var(--fg-muted);text-decoration:none;transition:color var(--dur-micro)}
.footer-legal a:hover{color:var(--ink)}

/* reveal */
.anim .reveal{opacity:0;transform:translateY(24px);transition:opacity .8s var(--ease-spring),transform .8s var(--ease-spring)}
.anim .reveal.in{opacity:1;transform:none}

/* ── responsive ── */
@media(max-width:1023px){
  .nav-toggle{display:flex}
  .site-nav{padding:var(--sp-2) var(--sp-3)}
  .nav-collapse{display:flex;flex-direction:column;align-items:stretch;gap:var(--sp-2);position:absolute;top:100%;left:0;right:0;padding:var(--sp-3);background:rgba(255,255,255,0.98);backdrop-filter:blur(20px);border-bottom:1px solid var(--border);box-shadow:0 16px 40px rgba(20,30,48,.10);transform:translateY(-12px);opacity:0;pointer-events:none;transition:transform var(--dur-std) var(--ease-spring),opacity var(--dur-micro)}
  .nav-collapse.open{transform:translateY(0);opacity:1;pointer-events:auto}
  .nav-links{flex-direction:column;gap:0}
  .nav-links li{border-bottom:1px solid var(--border)}
  .nav-links a{display:block;padding:.85rem .25rem;font-size:var(--text-base)}
  .nav-right{flex-direction:column;align-items:stretch;gap:var(--sp-1);margin-top:var(--sp-1)}
  .nav-login,.nav-cta{width:100%;text-align:center;padding:.75rem 1rem;min-height:44px}
  .lang-switch{width:100%}.lang-btn{width:100%;justify-content:center}
  .nav-collapse{max-height:calc(100vh - 64px);overflow-y:auto}
  .nav-mobile-extra{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-2) var(--sp-3);padding-top:var(--sp-2);border-top:1px solid var(--border);margin-top:var(--sp-1)}
  .nav-m-sect:first-child{grid-column:1/-1}
  .nav-m-sect:first-child ul{column-count:2;column-gap:var(--sp-3)}
  .nav-m-head{font-size:.6rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--fg-muted);margin:0 0 .45rem}
  .nav-m-sect ul{list-style:none;padding:0;margin:0}
  .nav-mobile-extra a{font-size:var(--text-sm);color:var(--fg-secondary);text-decoration:none;display:block;padding:.28rem 0;transition:color var(--dur-micro)}
  .nav-mobile-extra a:hover{color:var(--ink)}
  .footer-inner{grid-template-columns:1fr 1fr}
}
@media(max-width:600px){.footer-inner{grid-template-columns:1fr}.page{padding-top:calc(var(--sp-6) + 1rem)}}
