/*═══════════════════════════════════════════════════════════════
  MAMA WEBSITE — DARK THEME · CHROME/BLUE IDENTITY
  Primary: Electric Blue #0A84FF · Dark Navy · Italian Tricolore
  V6.1 — Readability, responsive & SEO audit fixes
═══════════════════════════════════════════════════════════════*/
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}

:root{
  --blue:#0A84FF;--blue-50:#0D1B2E;--blue-100:#112640;--blue-200:#1A3A5C;
  --blue-400:#3D9EFF;--blue-600:#0066D6;--blue-700:#004FA3;
  --blue-dim:rgba(10,132,255,.1);--blue-border:rgba(10,132,255,.2);
  --it-red:#E01E37;--it-green:#009246;
  --bg:#0B0F1A;--bg-alt:#0F1320;--bg-card:#131828;--bg-surface:#1A2035;
  --white:#FFFFFF;
  /* READABILITY: boosted --text-dim for better contrast on dark (WCAG AA 5.2:1) */
  --text:#E4E7ED;--text-dim:#A8AFBF;--text-muted:#7B8198;--text-faint:#4A4F63;
  --border:#1C2236;--border-l:#262D42;--border-ll:#333B54;
  --shadow-sm:0 1px 2px rgba(0,0,0,.3);--shadow:0 1px 3px rgba(0,0,0,.25);
  --shadow-md:0 4px 12px rgba(0,0,0,.3);--shadow-lg:0 12px 28px rgba(0,0,0,.35);
  --glow-b:rgba(10,132,255,.15);
  --font-d:'Outfit',sans-serif;--font-b:'DM Sans',sans-serif;--font-m:'JetBrains Mono',monospace;
  --max:1200px;--nav-h:72px;--ease:cubic-bezier(.22,1,.36,1);
  --card-radius:14px;--card-padding:2rem;
}

html{scroll-behavior:smooth;scroll-padding-top:calc(var(--nav-h) + 2rem)}
body{font-family:var(--font-b);background:var(--bg);color:var(--text);line-height:1.7;overflow-x:hidden;-webkit-font-smoothing:antialiased}
::-webkit-scrollbar{width:5px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:var(--blue);border-radius:3px}
::selection{background:var(--blue);color:#fff}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.container{max-width:var(--max);margin:0 auto;padding:0 2rem}

/*═══ TRICOLORE STRIPE ═══*/
.nav::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--it-green) 0%,var(--it-green) 33.3%,var(--white) 33.3%,var(--white) 66.6%,var(--it-red) 66.6%,var(--it-red) 100%);z-index:1}

/*═══ NAVIGATION ═══*/
.nav{position:fixed;top:0;left:0;right:0;z-index:1000;height:var(--nav-h);display:flex;align-items:center;background:rgba(11,15,26,.92);backdrop-filter:blur(24px) saturate(1.4);border-bottom:1px solid var(--border);transition:all .3s}
.nav.scrolled{background:rgba(11,15,26,.97);box-shadow:var(--shadow-md)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;width:100%;max-width:var(--max);margin:0 auto;padding:0 2rem}
.nav-logo{display:flex;align-items:center}
.nav-logo img{height:60px;width:auto}
.nav-logo .logo-sub{display:none}
.nav-menu{display:flex;align-items:center;gap:2px;list-style:none}
.nav-item>a,.nav-item>button{display:flex;align-items:center;padding:8px 14px;color:var(--text-dim);font-size:.85rem;font-weight:500;background:none;border:none;cursor:pointer;border-radius:8px;transition:all .2s;white-space:nowrap;font-family:var(--font-b)}
.nav-item>a:hover{color:var(--white);background:rgba(255,255,255,.05)}
.nav-item>a.active{color:var(--blue);font-weight:600}
.nav-right{display:flex;align-items:center;gap:12px}
.nav-cta{padding:9px 24px;background:var(--blue);color:#fff;border:none;border-radius:8px;font-family:var(--font-b);font-size:.85rem;font-weight:600;cursor:pointer;transition:all .3s;text-decoration:none;display:inline-block}
.nav-cta:hover{background:var(--blue-600);transform:translateY(-1px);box-shadow:0 4px 16px var(--glow-b)}
.nav-burger{display:none;background:none;border:none;color:var(--text);cursor:pointer;padding:8px}
.nav-burger svg{width:22px;height:22px}

/* MOBILE OVERLAY — RESPONSIVE: min 48px touch targets */
.mobile-overlay{display:none;position:fixed;inset:0;top:var(--nav-h);background:rgba(11,15,26,.98);backdrop-filter:blur(20px);z-index:999;padding:2rem;flex-direction:column;gap:.25rem;overflow-y:auto}
.mobile-overlay.open{display:flex}
.mobile-overlay a{color:var(--text);font-family:var(--font-d);font-size:1.05rem;font-weight:600;padding:.85rem 0;min-height:48px;display:flex;align-items:center;border-bottom:1px solid var(--border)}
/* RESPONSIVE: mobile CTA button inside overlay */
.mobile-overlay .mob-cta{display:block;margin-top:1.5rem;padding:14px 24px;background:var(--blue);color:#fff;border-radius:10px;text-align:center;font-weight:600;font-size:.95rem;font-family:var(--font-b)}

@media(max-width:1024px){.nav-menu,.nav-right .nav-cta{display:none}.nav-burger{display:block}}

/*═══ NAV DROPDOWN ═══*/
.nav-has-dd{position:relative}
.nav-has-dd>a{display:flex;align-items:center}
.nav-dropdown{position:absolute;top:calc(100% + 8px);left:50%;transform:translateX(-50%) translateY(-6px);min-width:280px;max-height:70vh;overflow-y:auto;background:var(--bg-card);border:1px solid var(--border-l);border-radius:14px;padding:8px;opacity:0;visibility:hidden;transition:all .25s var(--ease);box-shadow:var(--shadow-lg);z-index:100}
.nav-has-dd:hover .nav-dropdown{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.nav-dropdown a{display:block;padding:8px 14px;border-radius:10px;transition:all .15s;text-decoration:none}
.nav-dropdown a:hover{background:rgba(10,132,255,.08)}
.dd-label{font-weight:600;font-size:.85rem;color:var(--text)}
.dd-sub{font-size:.72rem;color:var(--text-muted);margin-top:1px}
.dd-section{font-family:var(--font-m);font-size:.64rem;color:var(--blue);letter-spacing:.12em;text-transform:uppercase;font-weight:600;padding:8px 14px 4px}
.nav-sep{height:1px;background:var(--border);margin:4px 8px}
.mobile-overlay .mob-section{font-size:.68rem;color:var(--blue);letter-spacing:.15em;text-transform:uppercase;font-family:var(--font-m);padding-top:1.25rem;padding-bottom:.25rem;border-bottom:none;min-height:auto}

/*═══ APP ═══*/
.main{min-height:100vh;padding-top:var(--nav-h)}

/*═══ HERO ═══*/
.hero{position:relative;min-height:88vh;display:flex;align-items:center;overflow:hidden;padding:4rem 0;background:var(--bg)}
.hero-pattern{position:absolute;inset:0;background-image:linear-gradient(var(--border) 1px,transparent 1px),linear-gradient(90deg,var(--border) 1px,transparent 1px);background-size:60px 60px;opacity:.12}
.hero-accent{position:absolute;top:-20%;right:-10%;width:50%;height:80%;background:radial-gradient(ellipse,rgba(10,132,255,.12),transparent 60%);pointer-events:none}
.hero-accent2{position:absolute;bottom:-15%;left:-5%;width:40%;height:60%;background:radial-gradient(ellipse,rgba(0,146,70,.06),transparent 60%);pointer-events:none}
.hero::after{content:'';position:absolute;top:0;left:0;width:100%;height:100%;background:repeating-linear-gradient(-25deg,transparent,transparent 100px,rgba(10,132,255,.025) 100px,rgba(10,132,255,.025) 102px);pointer-events:none}
.hero-content{position:relative;z-index:1;max-width:680px}
.hero-badge{display:inline-flex;align-items:center;gap:8px;padding:7px 18px;border:1px solid var(--blue-border);border-radius:100px;font-family:var(--font-m);font-size:.72rem;color:var(--blue-400);letter-spacing:.08em;text-transform:uppercase;margin-bottom:2rem;background:rgba(10,132,255,.06);backdrop-filter:blur(8px);animation:fadeUp .7s var(--ease)}
.hero-badge .pulse{width:7px;height:7px;border-radius:50%;background:var(--blue);animation:blink 2s infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.3}}
.hero h1{font-family:var(--font-d);font-size:clamp(2.6rem,6.5vw,5rem);font-weight:900;line-height:.97;letter-spacing:-.03em;margin-bottom:1.5rem;color:var(--white);animation:fadeUp .7s var(--ease) .1s both}
.hero h1 .accent{background:linear-gradient(135deg,var(--blue),var(--blue-400));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hero-sub{font-size:clamp(1rem,1.6vw,1.12rem);color:var(--text-dim);max-width:520px;line-height:1.75;margin-bottom:2.5rem;animation:fadeUp .7s var(--ease) .2s both}
.hero-actions{display:flex;gap:1rem;flex-wrap:wrap;animation:fadeUp .7s var(--ease) .3s both}
@keyframes fadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}

/*═══ BUTTONS ═══*/
.btn{display:inline-flex;align-items:center;gap:8px;padding:13px 26px;font-family:var(--font-b);font-weight:600;font-size:.9rem;border-radius:10px;border:none;cursor:pointer;transition:all .3s;text-decoration:none;white-space:nowrap;min-height:44px}
.btn-r{background:var(--blue);color:#fff;position:relative;overflow:hidden}
.btn-r::after{content:'';position:absolute;top:0;left:-100%;width:60%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.15),transparent);transition:left .5s}
.btn-r:hover::after{left:120%}
.btn-r:hover{background:var(--blue-600);transform:translateY(-2px);box-shadow:0 6px 20px var(--glow-b)}
.btn-o{background:transparent;color:var(--text);border:1px solid var(--border-l)}
.btn-o:hover{border-color:var(--border-ll);background:rgba(255,255,255,.03);transform:translateY(-2px)}
.btn-sm{padding:10px 18px;font-size:.84rem}
.btn-ghost{background:transparent;color:var(--blue);padding:8px 4px;font-size:.88rem}
.btn-ghost:hover{color:var(--blue-400)}
.btn-wa{background:#25D366;color:#fff}
.btn-wa:hover{background:#1EBE5A;transform:translateY(-2px);box-shadow:0 6px 20px rgba(37,211,102,.22)}

/*═══ STATS ═══*/
.stats{display:grid;grid-template-columns:repeat(4,1fr);border-top:3px solid var(--blue);border-bottom:1px solid var(--border);background:var(--bg-alt)}
.stats-item{padding:2.5rem 1.5rem;text-align:center;border-right:1px solid var(--border)}
.stats-item:last-child{border-right:none}
.stats-num{font-family:var(--font-d);font-size:clamp(1.8rem,3vw,2.6rem);font-weight:800;color:var(--blue);line-height:1;margin-bottom:.35rem}
.stats-num small{font-size:.4em;color:var(--text-muted)}
.stats-lbl{font-size:.78rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em;font-weight:500}
@media(max-width:768px){.stats{grid-template-columns:repeat(2,1fr)}.stats-item:nth-child(2){border-right:none}}
@media(max-width:480px){.stats{grid-template-columns:1fr}.stats-item{padding:1.75rem 1.25rem;border-right:none;border-bottom:1px solid var(--border)}.stats-item:last-child{border-bottom:none}}

/*═══ SECTIONS ═══*/
.sec{padding:80px 0;position:relative}
.sec-alt{background:var(--bg-alt)}
.sec-alt::before{content:'';position:absolute;inset:0;background:repeating-linear-gradient(-25deg,transparent,transparent 140px,rgba(10,132,255,.01) 140px,rgba(10,132,255,.01) 141px);pointer-events:none}
.sec-header{text-align:center;max-width:640px;margin:0 auto 3rem}
.sec-tag{font-family:var(--font-m);font-size:.72rem;color:var(--blue);letter-spacing:.18em;text-transform:uppercase;margin-bottom:.6rem;display:block;font-weight:600}
.sec-title{font-family:var(--font-d);font-size:clamp(1.75rem,3.2vw,2.5rem);font-weight:800;line-height:1.12;margin-bottom:.85rem;letter-spacing:-.02em;color:var(--white)}
.sec-desc{color:var(--text-dim);font-size:1rem;line-height:1.75}

/*═══ CARDS ═══*/
.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--card-radius);padding:var(--card-padding);transition:all .3s var(--ease)}
.card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);border-color:var(--border-l)}
.card-icon{width:44px;height:44px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.15rem;margin-bottom:1.25rem;background:var(--blue-dim);border:1px solid var(--blue-border)}
.card h3{font-family:var(--font-d);font-size:1.08rem;font-weight:700;margin-bottom:.5rem;color:var(--white)}
/* READABILITY: card paragraph text bumped to .9rem with 1.7 line-height */
.card p{color:var(--text-dim);font-size:.9rem;line-height:1.7}

/*═══ GRIDS ═══*/
.g2{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}
.g3{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.g4{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem}
.gAuto{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}

/*═══ MODULE CARDS ═══*/
.mod-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--card-radius);padding:1.75rem;transition:all .3s}
.mod-card:hover{box-shadow:var(--shadow-md);border-color:var(--border-l)}
.mod-card.core{grid-column:1/-1;background:var(--bg-surface);border-color:var(--blue-border)}
.mod-code{font-family:var(--font-m);font-size:.68rem;color:var(--blue);letter-spacing:.08em;margin-bottom:.4rem;display:block;font-weight:600}
.mod-card h3{font-family:var(--font-d);font-size:1.05rem;font-weight:700;margin-bottom:.5rem;color:var(--white)}
/* READABILITY: module card text bumped to .86rem */
.mod-card p{color:var(--text-dim);font-size:.86rem;line-height:1.7}
.mod-dep{margin-top:.75rem;padding-top:.75rem;border-top:1px solid var(--border);font-size:.72rem;color:var(--text-muted);font-family:var(--font-m)}
.mod-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.2rem}
.mod-dev{opacity:.7}
.dev-badge{display:inline-flex;align-items:center;padding:3px 10px;background:var(--blue-dim);border:1px solid var(--blue-border);border-radius:100px;font-family:var(--font-m);font-size:.64rem;font-weight:600;color:var(--blue);letter-spacing:.04em;text-transform:uppercase;white-space:nowrap}

/*═══ PRICING ═══*/
.price-card{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;padding:2.5rem 2rem;transition:all .3s;position:relative}
.price-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.price-card.feat{border-color:var(--blue);box-shadow:0 0 0 1px var(--blue),var(--shadow-md)}
.price-badge{position:absolute;top:1rem;right:1rem;padding:3px 10px;background:var(--blue);color:#fff;font-size:.68rem;font-weight:700;border-radius:100px;text-transform:uppercase;letter-spacing:.05em}
.price-name{font-family:var(--font-d);font-size:1.2rem;font-weight:700;margin-bottom:.5rem;color:var(--white)}
.price-desc{font-size:.84rem;color:var(--text-muted);margin-bottom:1rem;line-height:1.5}
.price-amount{font-family:var(--font-d);font-size:2.5rem;font-weight:800;line-height:1;margin-bottom:.15rem;color:var(--white)}
.price-amount small{font-size:.38em;font-weight:500;color:var(--text-muted)}
.price-note{font-size:.78rem;color:var(--text-muted);margin-bottom:1.5rem}
.price-list{list-style:none;margin-bottom:2rem}
.price-list li{padding:.4rem 0;font-size:.88rem;color:var(--text-dim);display:flex;align-items:flex-start;gap:8px;line-height:1.6}
.price-list li::before{content:'✓';color:var(--blue);font-weight:700;font-size:.8rem;flex-shrink:0;margin-top:3px}
.price-btn{display:block;width:100%;padding:13px;text-align:center;border-radius:10px;font-weight:600;font-size:.88rem;cursor:pointer;transition:all .3s;border:none;font-family:var(--font-b);min-height:44px}
.price-btn.fill{background:var(--blue);color:#fff}
.price-btn.fill:hover{background:var(--blue-600)}
.price-btn.line{background:transparent;color:var(--text);border:1px solid var(--border-l)}
.price-btn.line:hover{border-color:var(--border-ll);background:rgba(255,255,255,.03)}

/*═══ TABLE ═══*/
.tbl{width:100%;border-collapse:collapse;font-size:.88rem}
.tbl th{font-family:var(--font-d);font-weight:600;text-align:left;padding:12px 16px;border-bottom:2px solid var(--border-l);color:var(--text-dim);font-size:.78rem;text-transform:uppercase;letter-spacing:.06em}
.tbl td{padding:12px 16px;border-bottom:1px solid var(--border);color:var(--text-dim)}
.tbl tr:hover td{background:rgba(255,255,255,.02)}
.tbl .hl{color:var(--blue);font-weight:600}
.tbl-wrap{overflow-x:auto;border:1px solid var(--border);border-radius:12px;background:var(--bg-card);-webkit-overflow-scrolling:touch}
.tbl-wrap .tbl th:first-child,.tbl-wrap .tbl td:first-child{padding-left:20px}
.tbl-name{font-weight:600;color:var(--text)}
.tbl-sm{font-size:.78rem;color:var(--text-muted)}

/*═══ FAQ ═══*/
.faq-item{border:1px solid var(--border);border-radius:12px;margin-bottom:.75rem;background:var(--bg-card);overflow:hidden;transition:all .2s}
.faq-item:hover{border-color:var(--border-l)}
.faq-item.open{border-color:var(--blue-border);box-shadow:0 0 0 1px rgba(10,132,255,.1)}
.faq-q{display:flex;justify-content:space-between;align-items:center;cursor:pointer;font-family:var(--font-d);font-weight:600;font-size:.98rem;padding:1.25rem 1.5rem;color:var(--text);min-height:48px}
.faq-q::after{content:'+';font-size:1.3rem;color:var(--blue);transition:transform .3s;flex-shrink:0;margin-left:1rem}
.faq-item.open .faq-q::after{transform:rotate(45deg)}
.faq-item.open .faq-q{color:var(--blue)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s var(--ease);color:var(--text-dim);font-size:.92rem;line-height:1.75}
.faq-item.open .faq-a{max-height:600px;padding:0 1.5rem 1.25rem}

/*═══ FORM ═══*/
.form-group{margin-bottom:1.25rem}
.form-group label{display:block;font-size:.84rem;font-weight:600;color:var(--text-dim);margin-bottom:.4rem}
.form-input{width:100%;padding:12px 16px;background:var(--bg-surface);border:1px solid var(--border);border-radius:10px;color:var(--text);font-family:var(--font-b);font-size:.9rem;transition:all .2s;outline:none;min-height:44px}
.form-input:focus{border-color:var(--blue);box-shadow:0 0 0 3px var(--glow-b)}
.form-input::placeholder{color:var(--text-faint)}
textarea.form-input{min-height:140px;resize:vertical}
select.form-input{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%237B8198' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center}

/*═══ WHATSAPP ═══*/
.wa-float{position:fixed;bottom:24px;right:24px;z-index:900;width:56px;height:56px;border-radius:50%;background:#25D366;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 4px 14px rgba(37,211,102,.3);transition:all .3s;border:none;text-decoration:none}
.wa-float:hover{transform:scale(1.08);box-shadow:0 6px 24px rgba(37,211,102,.4)}
.wa-float svg{width:28px;height:28px;fill:#fff}

/*═══ PAGE HERO ═══*/
.page-hero{padding:3.5rem 0 2.5rem;background:var(--bg-alt);border-bottom:1px solid var(--border);position:relative;overflow:hidden;text-align:center}
.page-hero::after{content:'';position:absolute;top:0;right:0;bottom:0;width:40%;background:repeating-linear-gradient(-25deg,transparent,transparent 60px,rgba(10,132,255,.02) 60px,rgba(10,132,255,.02) 61px);pointer-events:none}
.page-hero>*{position:relative;z-index:1}
.breadcrumb{font-family:var(--font-m);font-size:.72rem;color:var(--text-muted);letter-spacing:.04em;margin-bottom:.75rem}
.breadcrumb a{color:var(--text-muted);transition:color .2s}
.breadcrumb a:hover{color:var(--blue)}
.breadcrumb .sep{margin:0 .4rem;opacity:.5}
.page-hero h1{font-family:var(--font-d);font-size:clamp(1.8rem,3.5vw,2.6rem);font-weight:800;letter-spacing:-.02em;margin-bottom:.6rem;color:var(--white)}
/* READABILITY: wider max-width to prevent awkward line breaks */
.page-hero p{color:var(--text-dim);font-size:1rem;max-width:680px;line-height:1.7;margin-left:auto;margin-right:auto}

/*═══ CTA BANNER ═══*/
.cta-banner{padding:5rem 0;text-align:center;background:var(--bg-alt);border-top:1px solid var(--border);border-bottom:1px solid var(--border);position:relative;overflow:hidden}
.cta-banner::before{content:'';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:500px;height:500px;background:radial-gradient(circle,var(--glow-b),transparent 60%);opacity:.6;pointer-events:none}
.cta-banner::after{content:'';position:absolute;inset:0;background:repeating-linear-gradient(-25deg,transparent,transparent 100px,rgba(10,132,255,.015) 100px,rgba(10,132,255,.015) 102px);pointer-events:none}
.cta-banner .container{position:relative;z-index:1}
.cta-banner h2{font-family:var(--font-d);font-size:clamp(1.6rem,3.5vw,2.5rem);font-weight:800;margin-bottom:.6rem;color:var(--white);letter-spacing:-.02em}
.cta-banner p{color:var(--text-dim);font-size:1rem;margin-bottom:2rem;max-width:440px;margin-left:auto;margin-right:auto}

/*═══ INFO BOX ═══*/
.info-box{background:var(--blue-dim);border:1px solid var(--blue-border);border-radius:12px;padding:1.5rem}
.info-box p{font-size:.88rem;color:var(--text-dim);line-height:1.65}
.info-box strong{color:var(--text)}

/*═══ FOOTER ═══*/
.footer{background:#060810;color:var(--text-dim);padding:0 0 2rem}
.footer-racing-line{height:3px;background:linear-gradient(90deg,var(--it-green) 0%,var(--it-green) 33.3%,var(--white) 33.3%,var(--white) 66.6%,var(--it-red) 66.6%,var(--it-red) 100%)}
.footer .container{padding-top:3rem}
.footer-grid{display:grid;grid-template-columns:2.2fr 1fr 1fr 1fr;gap:3rem;margin-bottom:3rem}
.footer-brand{display:flex;align-items:center;margin-bottom:.6rem}
.footer-brand img{height:40px;width:auto}
.footer-tagline{font-family:var(--font-m);font-size:.66rem;color:var(--text-faint);letter-spacing:.06em;text-transform:uppercase;margin-bottom:.75rem}
.footer-desc{font-size:.84rem;color:var(--text-muted);line-height:1.65;max-width:280px;margin-bottom:.8rem}
.footer-collab{font-size:.78rem;color:var(--text-faint);line-height:1.55;max-width:280px;border-top:1px solid var(--border);padding-top:.7rem}
.footer-collab strong{color:var(--text-dim);font-weight:600}
.footer-collab a,.footer-bottom a{color:inherit;text-decoration:none;transition:color .2s}
.footer-collab a:hover,.footer-bottom a:hover{color:var(--blue)}
.footer-col h4{font-family:var(--font-d);font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:var(--text);margin-bottom:1rem}
.footer-col a{display:block;color:var(--text-muted);font-size:.85rem;padding:.35rem 0;transition:color .2s}
.footer-col a:hover{color:var(--white)}
.footer-bottom{border-top:1px solid var(--border);padding-top:2rem;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}
.footer-copy{font-size:.78rem;color:var(--text-faint)}

/*═══ REVEAL ═══*/
.rv{opacity:0;transform:translateY(24px);transition:all .65s var(--ease)}
.rv.vis{opacity:1;transform:translateY(0)}
.rv-d1{transition-delay:.08s}.rv-d2{transition-delay:.16s}.rv-d3{transition-delay:.24s}

/*═══ UTILS ═══*/
.divider{height:1px;background:var(--border);margin:3rem 0}
.text-blue{color:var(--blue)}.text-center{text-align:center}
.mt-1{margin-top:1rem}.mt-2{margin-top:2rem}.mt-3{margin-top:3rem}
.mb-1{margin-bottom:1rem}.mb-2{margin-bottom:2rem}

/*═══════════════════════════════════════════════════════════════
  RESPONSIVE — comprehensive mobile fixes
═══════════════════════════════════════════════════════════════*/
@media(max-width:900px){
  .g2,.g3,.g4{grid-template-columns:1fr}
  .gAuto{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}
}
@media(max-width:640px){
  .container{padding:0 1.25rem}
  .gAuto{grid-template-columns:1fr}

  /* Hero: shorter on mobile */
  .hero{min-height:auto;padding:3rem 0 2.5rem}
  .hero h1{font-size:2.2rem}
  .hero-sub{font-size:.95rem;max-width:100%}
  .hero-badge{font-size:.65rem;padding:5px 14px}

  /* Sections: less padding */
  .sec{padding:50px 0}
  .sec-header{margin-bottom:2rem}

  /* Cards: tighter padding */
  .card{padding:1.5rem}
  .mod-card{padding:1.5rem}
  .mod-card.core{grid-column:auto}
  .price-card{padding:2rem 1.5rem}

  /* Contact form: stack email/phone */
  .form-2col{grid-template-columns:1fr !important}

  /* Page hero */
  .page-hero{padding:2.5rem 0 2rem}
  .page-hero h1{font-size:1.6rem}
  .page-hero p{max-width:100%}

  /* CTA banner */
  .cta-banner{padding:3rem 0}
  .cta-banner h2{font-size:1.5rem}

  /* Footer */
  .footer-grid{grid-template-columns:1fr;gap:1.5rem}
  .footer-bottom{flex-direction:column;align-items:flex-start;gap:.5rem}
  .footer-copy{font-size:.72rem}

  /* Table min-width to force scroll */
  .tbl{min-width:480px}
}

/* Tablet specific */
@media(min-width:641px) and (max-width:900px){
  .footer-grid{grid-template-columns:1fr 1fr;gap:2rem}
  .hero{min-height:70vh}
}
