
/* ============================================================
   STUDIO CAROLLO — Premium design system (light, palette originale)
   ============================================================ */
*,*::before,*::after{box-sizing:border-box}
:root{
  --bg:#ffffff; --bg-2:#f7f6f2; --panel:#ffffff; --panel-2:#fbfaf7;
  --ink:#20262f; --head:#15263f; --muted:#5e6976; --faint:#9aa3b0;
  --navy:#15263f; --navy-2:#1a2e4a;
  --accent:#335599; --accent-2:#5b82c4; --accent-d:#26406d; --accent-soft:rgba(51,85,153,.08);
  --gold:#c19a4e; --gold-2:#e0a93b;
  --line:#ebe9e3; --line-strong:rgba(21,38,63,.12); --line-accent:rgba(51,85,153,.22);
  --radius:20px; --radius-sm:12px; --maxw:1180px;
  --serif:"Playfair Display",Georgia,"Times New Roman",serif;
  --sans:"Inter",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  --shadow-sm:0 4px 16px rgba(20,30,50,.06);
  --shadow:0 18px 44px rgba(20,30,50,.10);
  --shadow-lg:0 30px 70px rgba(20,30,50,.16);
  --ease:cubic-bezier(.22,.61,.36,1);
}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{margin:0;font-family:var(--sans);color:var(--ink);background:var(--bg);line-height:1.7;font-size:17px;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden}
img{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none}
button{font-family:inherit}
h1,h2,h3,h4{font-family:var(--serif);color:var(--head);font-weight:600;line-height:1.14;letter-spacing:-.01em;margin:0}
p{margin:0 0 1rem}
::selection{background:var(--accent);color:#fff}
:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:4px}

.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 28px}
.section{position:relative;padding:120px 0}
.section-head{max-width:760px;margin:0 0 64px}
.section-head.center{margin-left:auto;margin-right:auto;text-align:center}
.eyebrow{display:inline-flex;align-items:center;gap:10px;font-family:var(--sans);
  font-size:.72rem;font-weight:700;letter-spacing:.26em;text-transform:uppercase;color:var(--accent);margin-bottom:22px}
.eyebrow::before{content:"";width:30px;height:1px;background:linear-gradient(90deg,transparent,var(--accent))}
.section-head.center .eyebrow::before{display:none}
.section-head h2{font-size:clamp(2rem,3.6vw,3.1rem)}
.section-head .lead,.lead{color:var(--muted);font-size:1.12rem;margin-top:18px}
.section-head .desc,.desc{color:var(--muted)}

.btn{position:relative;display:inline-flex;align-items:center;justify-content:center;gap:10px;
  font-family:var(--sans);font-weight:600;font-size:.95rem;letter-spacing:.01em;padding:15px 30px;border-radius:999px;
  border:1px solid transparent;cursor:pointer;transition:transform .35s var(--ease),box-shadow .35s var(--ease),background .35s,color .35s,border-color .35s;overflow:hidden;white-space:nowrap}
.btn .ar{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:2;transition:transform .35s var(--ease)}
.btn:hover .ar{transform:translateX(4px)}
.btn-primary{background:linear-gradient(120deg,var(--accent),var(--accent-2));color:#fff;box-shadow:0 14px 30px -12px rgba(51,85,153,.55)}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 22px 44px -14px rgba(51,85,153,.6)}
.btn-primary::after{content:"";position:absolute;inset:0;background:linear-gradient(120deg,transparent,rgba(255,255,255,.4),transparent);transform:translateX(-130%);transition:transform .7s var(--ease)}
.btn-primary:hover::after{transform:translateX(130%)}
.btn-ghost{background:transparent;color:var(--head);border-color:var(--line-accent)}
.btn-ghost:hover{background:var(--accent-soft);border-color:var(--accent);transform:translateY(-3px)}
.btn-light{background:#fff;color:var(--navy);box-shadow:var(--shadow-sm)}
.btn-light:hover{transform:translateY(-3px)}
.btn-block{width:100%}

.scroll-progress{position:fixed;top:0;left:0;height:3px;width:0;z-index:200;background:linear-gradient(90deg,var(--accent),var(--accent-2));transition:width .1s linear}
.skip{position:absolute;left:-999px;top:0;background:var(--accent);color:#fff;padding:10px 16px;z-index:300;border-radius:0 0 8px 0}
.skip:focus{left:0}

/* Header */
.site-header{position:fixed;top:0;left:0;right:0;z-index:120;padding:20px 0;
  transition:padding .4s var(--ease),background .4s,border-color .4s,box-shadow .4s;border-bottom:1px solid transparent}
.site-header.scrolled{padding:12px 0;background:rgba(255,255,255,.86);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  border-bottom-color:var(--line);box-shadow:0 6px 24px -16px rgba(20,30,50,.3)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:24px}
.brand{display:flex;align-items:center;gap:13px}
.brand .logo{width:42px;height:42px;border-radius:11px}
.bwrap{display:flex;flex-direction:column;line-height:1.1}
.bwrap b{font-family:var(--serif);font-size:1.12rem;color:var(--head);letter-spacing:.02em}
.bwrap i{font-style:normal;font-size:.66rem;letter-spacing:.24em;text-transform:uppercase;color:var(--accent);margin-top:3px}
.nav-links{list-style:none;display:flex;align-items:center;gap:6px;margin:0;padding:0}
.nav-links a{position:relative;padding:9px 15px;font-size:.92rem;font-weight:500;color:var(--ink);border-radius:8px;transition:color .3s}
.nav-links a:not(.btn)::after{content:"";position:absolute;left:15px;right:15px;bottom:4px;height:1.5px;background:linear-gradient(90deg,var(--accent),var(--accent-2));transform:scaleX(0);transform-origin:left;transition:transform .35s var(--ease)}
.nav-links a:not(.btn):hover{color:var(--accent)}
.nav-links a:not(.btn):hover::after{transform:scaleX(1)}
.nav-cta{margin-left:12px}
.nav-cta .btn{padding:11px 22px}
.nav-toggle{display:none;flex-direction:column;justify-content:center;gap:5px;width:46px;height:46px;background:transparent;border:1px solid var(--line-strong);border-radius:11px;cursor:pointer}
.nav-toggle span{display:block;width:20px;height:2px;background:var(--head);margin:0 auto;transition:.35s var(--ease)}
.nav-toggle.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle.open span:nth-child(2){opacity:0}
.nav-toggle.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* Hero */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;padding:140px 0 90px;overflow:hidden}
.hero-bg{position:absolute;inset:0;z-index:0;
  background:
    radial-gradient(1100px 620px at 80% 10%,#eaf0f8,transparent 60%),
    radial-gradient(900px 700px at 8% 92%,#f4f7fb,transparent 60%),
    linear-gradient(180deg,#ffffff,#f8fafc 60%,#ffffff)}
.hero-bg::before{content:"";position:absolute;inset:0;
  background-image:linear-gradient(rgba(21,38,63,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(21,38,63,.05) 1px,transparent 1px);
  background-size:64px 64px;mask-image:radial-gradient(circle at 72% 28%,#000,transparent 72%);opacity:.7}
.hero-inner{position:relative;z-index:2;display:grid;grid-template-columns:1.05fr .95fr;gap:60px;align-items:center;width:100%}
.hero-badge{display:inline-flex;align-items:center;gap:9px;padding:8px 16px;border-radius:999px;border:1px solid var(--line-accent);
  background:var(--accent-soft);color:var(--accent-d);font-size:.74rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;margin-bottom:26px}
.hero-badge .dot{width:7px;height:7px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 4px rgba(51,85,153,.16)}
.hero h1{font-size:clamp(2.5rem,5.4vw,4.3rem);color:var(--head);margin-bottom:24px}
.hero h1 .mark{color:transparent;background:linear-gradient(120deg,var(--gold),var(--gold-2));-webkit-background-clip:text;background-clip:text;font-style:italic;padding:.16em .2em .06em 0;margin-right:-.14em}
.hero .lead{font-size:1.2rem;color:var(--muted);max-width:540px;margin-bottom:36px}
.hero-actions{display:flex;flex-wrap:wrap;gap:16px;margin-bottom:40px}
.hero-assure{display:flex;flex-wrap:wrap;gap:22px}
.hero-assure .li{display:flex;align-items:center;gap:9px;font-size:.9rem;color:var(--muted)}
.hero-assure .li svg{width:18px;height:18px;stroke:var(--accent);fill:none;stroke-width:2}

/* Hero visual card (light glass) */
.hero-mono{position:relative;perspective:1400px}
.hero-card{position:relative;background:#ffffff;border:1px solid var(--line);border-radius:var(--radius);padding:30px;
  box-shadow:var(--shadow-lg);transform:rotateY(-9deg) rotateX(4deg);transition:transform .8s var(--ease)}
.hero-mono:hover .hero-card{transform:rotateY(-4deg) rotateX(2deg)}
.hero-card .hc-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:22px}
.hero-card .hc-top b{font-family:var(--serif);color:var(--head);font-size:1.05rem}
.hero-card .hc-tag{font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);border:1px solid var(--line-accent);border-radius:999px;padding:4px 11px}
.hc-bars{display:flex;align-items:flex-end;gap:11px;height:130px;margin-bottom:24px}
.hc-bars span{flex:1;border-radius:7px 7px 3px 3px;background:linear-gradient(180deg,var(--accent),rgba(91,130,196,.35));transform-origin:bottom;animation:grow 1.1s var(--ease) both}
.hc-bars span:nth-child(2){animation-delay:.1s}.hc-bars span:nth-child(3){animation-delay:.2s}
.hc-bars span:nth-child(4){animation-delay:.3s}.hc-bars span:nth-child(5){animation-delay:.4s}
@keyframes grow{from{transform:scaleY(0)}to{transform:scaleY(1)}}
.hc-rows{display:flex;flex-direction:column;gap:13px}
.hc-row{display:flex;align-items:center;justify-content:space-between;font-size:.86rem}
.hc-row span:first-child{color:var(--muted)}
.hc-row span:last-child{color:var(--head);font-weight:600;font-variant-numeric:tabular-nums}
.hero-chip{position:absolute;background:#fff;border:1px solid var(--line);border-radius:14px;padding:13px 17px;box-shadow:var(--shadow);display:flex;align-items:center;gap:11px}
.hero-chip svg{width:22px;height:22px;stroke:var(--accent);fill:none;stroke-width:2}
.hero-chip b{display:block;font-family:var(--serif);color:var(--head);font-size:1rem;line-height:1}
.hero-chip i{font-style:normal;font-size:.72rem;color:var(--muted)}
.hero-chip.c1{top:-26px;left:-30px;animation:float 5s ease-in-out infinite}
.hero-chip.c2{bottom:-24px;right:-26px;animation:float 5s ease-in-out infinite .8s}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}
.scroll-cue{position:absolute;bottom:30px;left:50%;transform:translateX(-50%);z-index:2;display:flex;flex-direction:column;align-items:center;gap:8px;color:var(--faint);font-size:.7rem;letter-spacing:.2em;text-transform:uppercase}
.scroll-cue .mouse{width:24px;height:38px;border:1.5px solid var(--line-accent);border-radius:13px;position:relative}
.scroll-cue .mouse::after{content:"";position:absolute;top:7px;left:50%;width:3px;height:7px;border-radius:2px;background:var(--accent);transform:translateX(-50%);animation:wheel 1.6s infinite}
@keyframes wheel{0%{opacity:1;top:7px}70%{opacity:0;top:18px}100%{opacity:0}}

/* Trust counters */
.trust{padding:0 0 30px}
.trust-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px}
.trust-grid>div{position:relative;text-align:center;padding:38px 24px;border-radius:var(--radius);background:#fff;border:1px solid var(--line);box-shadow:var(--shadow-sm);transition:transform .45s var(--ease),box-shadow .45s}
.trust-grid>div:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.trust-grid b{display:block;font-family:var(--serif);font-size:2.9rem;color:transparent;background:linear-gradient(120deg,var(--navy),var(--accent));-webkit-background-clip:text;background-clip:text;font-variant-numeric:tabular-nums;line-height:1}
.trust-grid .tl{display:block;margin-top:10px;color:var(--head);font-weight:600}
.trust-grid .ts{display:block;color:var(--muted);font-size:.9rem;margin-top:2px}

.grid{display:grid;gap:26px}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}

/* Service cards */
.service{position:relative;padding:38px 32px;border-radius:var(--radius);background:#fff;border:1px solid var(--line);box-shadow:var(--shadow-sm);overflow:hidden;transition:transform .5s var(--ease),box-shadow .5s,border-color .5s}
.service::before{content:"";position:absolute;left:0;top:0;right:0;height:3px;background:linear-gradient(90deg,var(--accent),var(--accent-2));transform:scaleX(0);transform-origin:left;transition:transform .5s var(--ease)}
.service:hover{transform:translateY(-8px);box-shadow:var(--shadow);border-color:var(--line-accent)}
.service:hover::before{transform:scaleX(1)}
.service .ic{position:relative;width:58px;height:58px;border-radius:15px;display:grid;place-items:center;background:var(--accent-soft);border:1px solid var(--line-accent);margin-bottom:22px;transition:transform .5s var(--ease)}
.service:hover .ic{transform:scale(1.08) rotate(-4deg)}
.service .ic svg{width:27px;height:27px;stroke:var(--accent);fill:none;stroke-width:1.8}
.service h3{font-size:1.32rem;margin-bottom:12px}
.service p{color:var(--muted);font-size:.97rem;margin-bottom:18px}
.service .more{display:inline-flex;align-items:center;gap:8px;color:var(--accent);font-weight:600;font-size:.9rem}
.service .more svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:2;transition:transform .35s var(--ease)}
.service:hover .more svg{transform:translateX(4px)}
.service .snum{position:absolute;top:26px;right:30px;font-family:var(--serif);font-size:1.1rem;color:var(--line-strong)}

/* Service dark/navy highlight card (CTA inside services) */
.service-dark{background:linear-gradient(150deg,var(--navy),var(--navy-2))!important;border-color:transparent!important;box-shadow:var(--shadow)}
.service-dark::before{display:none}
.service-dark h3{color:#fff}
.service-dark p{color:rgba(255,255,255,.78)}

/* Feature cards */
.feature{padding:30px 28px;border-radius:var(--radius-sm);border:1px solid var(--line);background:#fff;box-shadow:var(--shadow-sm);transition:transform .45s var(--ease),box-shadow .45s,border-color .45s}
.feature:hover{transform:translateY(-5px);box-shadow:var(--shadow);border-color:var(--line-accent)}
.feature .ic{width:48px;height:48px;border-radius:12px;display:grid;place-items:center;background:var(--accent-soft);border:1px solid var(--line-accent);margin-bottom:18px;transition:transform .45s var(--ease)}
.feature:hover .ic{transform:rotate(-6deg) scale(1.06)}
.feature .ic svg{width:23px;height:23px;stroke:var(--accent);fill:none;stroke-width:1.8}
.feature h3{font-size:1.12rem;margin-bottom:9px}
.feature p{color:var(--muted);font-size:.92rem;margin:0}

/* Method steps */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:26px;position:relative}
.steps::before{content:"";position:absolute;top:34px;left:8%;right:8%;height:1px;background:linear-gradient(90deg,transparent,var(--line-accent),transparent);z-index:0}
.step{position:relative;z-index:1;text-align:center;padding:0 8px}
.step .step-n{width:70px;height:70px;margin:0 auto 22px;border-radius:50%;display:grid;place-items:center;font-family:var(--serif);font-size:1.5rem;color:var(--accent);background:#fff;border:1px solid var(--line-accent);box-shadow:0 0 0 8px var(--bg),0 12px 28px -12px rgba(51,85,153,.4);transition:transform .45s var(--ease),color .45s,background .45s}
.step:hover .step-n{transform:translateY(-6px);color:#fff;background:linear-gradient(120deg,var(--accent),var(--accent-2))}
.step h3{font-size:1.18rem;margin-bottom:9px}
.step p{color:var(--muted);font-size:.92rem;margin:0}

/* About */
.about{display:grid;grid-template-columns:.85fr 1.15fr;gap:60px;align-items:center}
.about .frame{position:relative}
.about .portrait{border-radius:var(--radius);border:1px solid var(--line);box-shadow:var(--shadow-lg);width:100%;object-fit:cover;aspect-ratio:4/5}
.about .frame::before{content:"";position:absolute;inset:-16px -16px 24px 24px;border:1px solid var(--line-accent);border-radius:var(--radius);z-index:-1}
.about .cap{position:absolute;bottom:18px;left:18px;right:18px;background:rgba(255,255,255,.94);border:1px solid var(--line);border-radius:14px;padding:14px 18px;backdrop-filter:blur(8px);box-shadow:var(--shadow-sm)}
.about .cap b{display:block;font-family:var(--serif);color:var(--head);font-size:1.02rem}
.about .cap span{font-size:.82rem;color:var(--accent)}
.about h2{font-size:clamp(1.9rem,3.4vw,2.9rem);margin-bottom:20px}
.about p{color:var(--ink);margin-bottom:16px}
.creds{list-style:none;margin:26px 0 30px;padding:0;display:grid;grid-template-columns:1fr 1fr;gap:14px}
.creds li{display:flex;gap:12px;align-items:flex-start;font-size:.93rem;color:var(--ink)}
.creds li svg{width:20px;height:20px;flex:none;stroke:var(--accent);fill:none;stroke-width:2;margin-top:2px}

/* Per chi */
.aud{padding:30px 26px;border-radius:var(--radius-sm);border:1px solid var(--line);background:#fff;box-shadow:var(--shadow-sm);transition:transform .45s var(--ease),box-shadow .45s,border-color .45s}
.aud:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:var(--line-accent)}
.aud .ic{width:50px;height:50px;border-radius:13px;display:grid;place-items:center;background:var(--accent-soft);border:1px solid var(--line-accent);margin-bottom:18px;transition:transform .45s var(--ease)}
.aud:hover .ic{transform:scale(1.08)}
.aud .ic svg{width:24px;height:24px;stroke:var(--accent);fill:none;stroke-width:1.8}
.aud h3{font-size:1.16rem;margin-bottom:9px}
.aud p{color:var(--muted);font-size:.92rem;margin:0}

/* CTA band (navy) */
.cta-band{position:relative;overflow:hidden}
.band{position:relative;border-radius:26px;padding:72px 56px;text-align:center;overflow:hidden;background:linear-gradient(135deg,var(--navy),var(--navy-2));box-shadow:var(--shadow-lg)}
.band-bg{position:absolute;inset:0;z-index:0;background:radial-gradient(700px 380px at 50% -10%,rgba(91,130,196,.3),transparent 65%)}
.band-bg::after{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.06) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.06) 1px,transparent 1px);background-size:54px 54px;opacity:.6;mask-image:radial-gradient(circle at 50% 40%,#000,transparent 70%)}
.band-inner{position:relative;z-index:1}
.band h2{color:#fff;font-size:clamp(1.9rem,3.6vw,3rem);margin-bottom:18px}
.band p{color:rgba(255,255,255,.82);max-width:620px;margin:0 auto 32px}
.band .hero-actions{justify-content:center}
.band .btn-primary{background:linear-gradient(120deg,var(--gold),var(--gold-2));color:#1b1206;box-shadow:0 14px 30px -12px rgba(224,169,59,.5)}

/* Blog cards */
.post-card{display:flex;flex-direction:column;border-radius:var(--radius);overflow:hidden;background:#fff;border:1px solid var(--line);box-shadow:var(--shadow-sm);transition:transform .5s var(--ease),box-shadow .5s,border-color .5s}
.post-card:hover{transform:translateY(-8px);box-shadow:var(--shadow);border-color:var(--line-accent)}
.post-card-img{position:relative;display:block;aspect-ratio:16/10;overflow:hidden}
.post-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
.post-card:hover .post-card-img img{transform:scale(1.07)}
.post-cat{position:absolute;top:14px;left:14px;z-index:2;font-size:.7rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#fff;background:rgba(21,38,63,.78);border:1px solid rgba(255,255,255,.18);padding:6px 12px;border-radius:999px;backdrop-filter:blur(6px)}
.post-card-body{padding:26px 26px 28px;display:flex;flex-direction:column;flex:1}
.post-card-date{font-size:.78rem;letter-spacing:.06em;text-transform:uppercase;color:var(--faint);margin-bottom:12px}
.post-card-body h3{font-size:1.2rem;line-height:1.3;margin-bottom:14px}
.post-card-body h3 a{transition:color .3s}
.post-card:hover .post-card-body h3 a{color:var(--accent)}
.post-card-body p{color:var(--muted);font-size:.94rem;margin-bottom:18px}
.post-card-link{margin-top:auto;display:inline-flex;align-items:center;gap:8px;color:var(--accent);font-weight:600;font-size:.9rem}
.post-card-link svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:2;transition:transform .35s var(--ease)}
.post-card:hover .post-card-link svg{transform:translateX(4px)}

/* FAQ accordion */
.faq-item{border:1px solid var(--line);border-radius:var(--radius-sm);margin-bottom:14px;overflow:hidden;background:#fff;box-shadow:var(--shadow-sm);transition:border-color .4s,box-shadow .4s}
.faq-item.open{border-color:var(--line-accent);box-shadow:var(--shadow)}
.faq-q{width:100%;display:flex;align-items:center;justify-content:space-between;gap:20px;text-align:left;background:transparent;border:0;cursor:pointer;padding:24px 26px;font-family:var(--serif);font-size:1.12rem;color:var(--head);transition:color .3s}
.faq-q:hover{color:var(--accent)}
.faq-q .pm{position:relative;flex:none;width:22px;height:22px}
.faq-q .pm::before,.faq-q .pm::after{content:"";position:absolute;background:var(--accent);transition:transform .4s var(--ease)}
.faq-q .pm::before{top:50%;left:0;right:0;height:2px;transform:translateY(-50%)}
.faq-q .pm::after{left:50%;top:0;bottom:0;width:2px;transform:translateX(-50%)}
.faq-item.open .faq-q .pm::after{transform:translateX(-50%) scaleY(0)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .5s var(--ease)}
.faq-a p{color:var(--muted);font-size:.97rem;padding:0 26px 24px;margin:0}

/* Contact */
.contact{display:grid;grid-template-columns:1fr 1.05fr;gap:56px;align-items:start}
.contact-info .lead{margin-bottom:30px}
.contact-info .line{display:flex;gap:16px;align-items:flex-start;margin-bottom:24px}
.contact-info .line .ic{width:46px;height:46px;border-radius:12px;flex:none;display:grid;place-items:center;background:var(--accent-soft);border:1px solid var(--line-accent);transition:transform .4s var(--ease)}
.contact-info .line:hover .ic{transform:scale(1.08)}
.contact-info .line .ic svg{width:21px;height:21px;stroke:var(--accent);fill:none;stroke-width:1.8}
.contact-info .line b{display:block;color:var(--head);font-family:var(--serif);font-size:1.02rem;margin-bottom:2px}
.contact-info .line span,.contact-info .line a{color:var(--muted);font-size:.95rem}
.contact-info .line a:hover{color:var(--accent)}
.trust-badges{display:flex;flex-wrap:wrap;gap:12px;margin-top:30px}
.trust-badges span{display:inline-flex;align-items:center;gap:8px;font-size:.82rem;color:var(--ink);border:1px solid var(--line);border-radius:999px;padding:8px 15px;background:#fff;box-shadow:var(--shadow-sm)}
.trust-badges svg{width:15px;height:15px;stroke:var(--accent);fill:none;stroke-width:2}

/* Form */
.contact-form{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:36px;box-shadow:var(--shadow)}
.field{margin-bottom:20px}
.field label{display:block;font-size:.86rem;font-weight:600;color:var(--head);margin-bottom:9px}
.field input,.field textarea{width:100%;background:var(--bg-2);border:1px solid var(--line);border-radius:11px;padding:14px 16px;color:var(--ink);font-family:inherit;font-size:.97rem;transition:border-color .3s,box-shadow .3s,background .3s}
.field input::placeholder,.field textarea::placeholder{color:var(--faint)}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--accent);background:#fff;box-shadow:0 0 0 3px var(--accent-soft)}
.field textarea{min-height:130px;resize:vertical}
.hp{position:absolute!important;left:-9999px!important;width:1px;height:1px;opacity:0}
.form-status{font-size:.92rem;margin:14px 0 0;min-height:1.2em}
.form-status.ok{color:#1f7a4d}.form-status.err{color:#c0392b}
.form-note{font-size:.82rem;color:var(--faint);margin:14px 0 0}
.form-note a{color:var(--accent)}
.legal-note{font-size:.78rem;color:var(--faint)}

/* Footer (navy) */
.site-footer{position:relative;padding:80px 0 36px;background:linear-gradient(180deg,var(--navy),var(--navy-2));color:rgba(255,255,255,.7)}
.foot-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:48px;margin-bottom:48px}
.flogo{width:46px;height:46px;border-radius:12px;margin-bottom:16px;background:#fff;padding:4px}
.fbrand{font-family:var(--serif);font-size:1.3rem;color:#fff;margin-bottom:14px}
.site-footer p{color:rgba(255,255,255,.62);font-size:.92rem;max-width:340px}
.site-footer h4{font-family:var(--sans);font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-2);margin-bottom:20px}
.foot-links{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:11px}
.foot-links a,.foot-links li{color:rgba(255,255,255,.7);font-size:.93rem;transition:color .3s}
.foot-links a:hover{color:#fff}
.foot-bottom{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;padding-top:28px;border-top:1px solid rgba(255,255,255,.12);color:rgba(255,255,255,.5);font-size:.85rem}
.foot-bottom a{color:rgba(255,255,255,.5);margin-left:18px;transition:color .3s}
.foot-bottom a:hover{color:#fff}

/* Back to top + sticky CTA */
#toTop{position:fixed;bottom:26px;right:26px;z-index:90;width:50px;height:50px;border-radius:50%;background:linear-gradient(120deg,var(--accent),var(--accent-2));color:#fff;border:0;cursor:pointer;display:grid;place-items:center;opacity:0;transform:translateY(20px) scale(.8);pointer-events:none;transition:opacity .4s,transform .4s var(--ease);box-shadow:0 14px 30px -12px rgba(51,85,153,.6)}
#toTop.show{opacity:1;transform:none;pointer-events:auto}
#toTop svg{width:20px;height:20px;stroke:currentColor;fill:none;stroke-width:2.4}
.sticky-cta{position:fixed;left:0;right:0;bottom:0;z-index:95;display:none;padding:12px 16px;background:rgba(255,255,255,.96);backdrop-filter:blur(14px);border-top:1px solid var(--line);box-shadow:0 -8px 24px -16px rgba(20,30,50,.3)}
.sticky-cta .btn{width:100%}

/* Reveal */
.reveal{opacity:0;transform:translateY(34px);filter:blur(6px);transition:opacity .8s var(--ease),transform .8s var(--ease),filter .8s var(--ease)}
.reveal.show{opacity:1;transform:none;filter:none}
.reveal[data-d="1"]{transition-delay:.08s}.reveal[data-d="2"]{transition-delay:.16s}.reveal[data-d="3"]{transition-delay:.24s}.reveal[data-d="4"]{transition-delay:.32s}.reveal[data-d="5"]{transition-delay:.4s}

/* Article / subpage */
.subpage{padding-top:130px}
.crumbs{font-size:.85rem;color:var(--faint);margin-bottom:24px;display:flex;gap:8px;flex-wrap:wrap}
.crumbs a{color:var(--muted)}.crumbs a:hover{color:var(--accent)}
.post-wrap{max-width:820px;margin:0 auto}
.post-meta{display:flex;flex-wrap:wrap;align-items:center;gap:14px;color:var(--faint);font-size:.85rem;margin-bottom:22px}
.post-meta .post-cat{position:static}
.post-title{font-size:clamp(2rem,4.4vw,3.1rem);line-height:1.12;margin-bottom:24px}
.post-figure{margin:0 0 38px;border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow-sm)}
.post-figure img{width:100%}
.post-content{font-size:1.07rem;color:var(--ink)}
.post-content h2{font-size:1.7rem;margin:46px 0 16px;color:var(--head)}
.post-content h3{font-size:1.3rem;margin:34px 0 12px}
.post-content p{margin:0 0 18px}
.post-content ul,.post-content ol{margin:0 0 20px;padding-left:22px}
.post-content li{margin-bottom:9px}
.post-content a{color:var(--accent);text-decoration:underline;text-underline-offset:3px}
.post-content blockquote,.quote{border-left:3px solid var(--accent);background:var(--bg-2);margin:28px 0;padding:18px 24px;border-radius:0 12px 12px 0;color:var(--head);font-style:italic}
.post-content strong{color:var(--head)}
.post-cta{margin:46px 0;padding:34px;border-radius:var(--radius);text-align:center;background:linear-gradient(135deg,var(--navy),var(--navy-2));box-shadow:var(--shadow)}
.post-cta h3{font-size:1.5rem;margin-bottom:12px;color:#fff}
.post-cta p{color:rgba(255,255,255,.8);margin-bottom:22px}
.post-back{display:inline-flex;align-items:center;gap:9px;color:var(--accent);font-weight:600;margin-top:30px}
.post-back svg{width:17px;height:17px;stroke:currentColor;fill:none;stroke-width:2}

/* Utilities */
.mono{font-variant-numeric:tabular-nums}
.alt{background:var(--bg-2)}
.light{background:#fff;color:var(--ink)}
.stars{color:var(--gold-2)}
.post-cta .btn-primary{background:linear-gradient(120deg,var(--gold),var(--gold-2));color:#1b1206;box-shadow:0 14px 30px -12px rgba(224,169,59,.5)}

/* RESPONSIVE */
@media(max-width:1024px){
  .hero-inner{grid-template-columns:1fr;gap:54px}
  .hero-mono{max-width:460px;margin:0 auto;order:2}
  .about{grid-template-columns:1fr;gap:40px}
  .about .frame{max-width:420px}
  .contact{grid-template-columns:1fr;gap:40px}
  .grid-4{grid-template-columns:repeat(2,1fr)}
  .steps{grid-template-columns:repeat(2,1fr);gap:40px 26px}
  .steps::before{display:none}
}
@media(max-width:860px){
  .nav-links{position:fixed;top:0;right:0;height:100vh;width:min(340px,84vw);z-index:130;flex-direction:column;align-items:stretch;justify-content:flex-start;gap:6px;padding:96px 26px 40px;background:#fff;border-left:1px solid var(--line);transform:translateX(105%);transition:transform .5s var(--ease);box-shadow:-30px 0 60px -30px rgba(20,30,50,.3)}
  .nav-links.open{transform:none}
  .nav-links a{padding:14px 16px;font-size:1.05rem;border-radius:10px}
  .nav-links a:not(.btn)::after{display:none}
  .nav-links a:not(.btn):hover{background:var(--accent-soft)}
  .nav-cta{margin:14px 0 0}
  .nav-cta .btn{width:100%;padding:15px}
  .nav-toggle{display:flex;position:relative;z-index:140}
  body.menu-open{overflow:hidden}
  body.menu-open::after{content:"";position:fixed;inset:0;background:rgba(21,38,63,.45);z-index:125;backdrop-filter:blur(3px)}
}
@media(max-width:720px){
  body{font-size:16px}
  .section{padding:84px 0}
  .section-head{margin-bottom:44px}
  .grid-2,.grid-3,.grid-4{grid-template-columns:1fr}
  .trust-grid{grid-template-columns:1fr;gap:16px}
  .steps{grid-template-columns:1fr}
  .creds{grid-template-columns:1fr}
  .hero{min-height:auto;padding:120px 0 70px}
  .hero h1{font-size:clamp(2.2rem,8vw,3rem)}
  .hero-actions .btn{flex:1 1 100%}
  .band{padding:48px 26px}
  .contact-form{padding:26px}
  .foot-grid{grid-template-columns:1fr;gap:34px}
  .foot-bottom{flex-direction:column;align-items:flex-start;gap:10px}
  .foot-bottom a{margin:0 18px 0 0}
  .scroll-cue{display:none}
  .sticky-cta{display:block}
  #toTop{bottom:74px}
  .container{padding:0 20px}
  .hero-chip.c1{left:-6px;top:-18px}.hero-chip.c2{right:-6px}
}
@media(prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}
  .reveal{opacity:1;transform:none;filter:none}
}
