@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800;900&display=swap');
*{margin:0;padding:0;box-sizing:border-box}
:root{--g:#10B981;--gd:#059669;--gl:#D1FAE5;--n:#0F172A;--n7:#1E293B;--n5:#475569;--s4:#94A3B8;--s3:#CBD5E1;--s2:#E2E8F0;--s1:#F1F5F9;--s0:#F8FAFC;--o:#F97316;--ol:#FFF7ED;--r:#EF4444;--rl:#FEE2E2;--b:#3B82F6;--bl:#DBEAFE}
body{font-family:'Inter',system-ui,sans-serif;color:var(--n);-webkit-font-smoothing:antialiased}
a{text-decoration:none;color:inherit;cursor:pointer}
@keyframes fadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
@keyframes slideUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
.fade-in{animation:fadeIn .3s ease}.slide-up{animation:slideUp .3s ease}
.hidden{display:none!important}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;border:none;transition:all .2s;font-family:inherit;line-height:1}
.btn:hover{transform:translateY(-1px)}.btn:disabled{opacity:.5;cursor:default;transform:none}
.btn-primary{background:var(--g);color:#fff}.btn-primary:hover{background:var(--gd);box-shadow:0 4px 14px rgba(16,185,129,.3)}
.btn-dark{background:var(--n);color:#fff}.btn-dark:hover{background:var(--n7)}
.btn-outline{background:0 0;border:1.5px solid var(--s2);color:var(--n)}.btn-outline:hover{border-color:var(--s3);background:var(--s0)}
.btn-outline-white{background:0 0;border:1.5px solid rgba(255,255,255,.25);color:#fff}.btn-outline-white:hover{border-color:rgba(255,255,255,.5)}
.btn-danger{background:var(--r);color:#fff}
.btn-ghost{background:0 0;color:var(--n5);padding:6px 12px;font-size:13px}.btn-ghost:hover{background:var(--s1)}
.btn-sm{padding:6px 14px;font-size:12px}

/* Forms */
.field{display:flex;flex-direction:column;gap:4px;min-width:0}
.field label{font-size:11px;font-weight:600;color:var(--n5);text-transform:uppercase;letter-spacing:.5px}
.field input,.field select{padding:10px 12px;border:1.5px solid var(--s2);border-radius:8px;font-size:13px;color:var(--n);background:#fff;transition:all .2s;outline:none;font-family:inherit;width:100%;box-sizing:border-box}
.field input:focus,.field select:focus{border-color:var(--g);box-shadow:0 0 0 3px rgba(16,185,129,.1)}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.form-grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px}
.form-col{display:flex;flex-direction:column;gap:14px}

/* Badges */
.badge{display:inline-flex;align-items:center;padding:4px 10px;border-radius:20px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.4px}
.badge-green{background:var(--gl);color:#047857}.badge-blue{background:var(--bl);color:#1D4ED8}
.badge-orange{background:var(--ol);color:#C2410C}.badge-red{background:var(--rl);color:var(--r)}

/* Cards & Tables */
.card{background:#fff;border:1px solid var(--s2);border-radius:12px;padding:24px}
.stat-card{background:#fff;border:1px solid var(--s2);border-radius:12px;padding:16px 20px}
.stat-label{font-size:11px;font-weight:600;color:var(--n5);text-transform:uppercase;letter-spacing:.5px}
.stat-val{font-size:28px;font-weight:800;margin-top:4px}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:24px}
table{width:100%;border-collapse:collapse}
thead th{text-align:left;padding:12px 16px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--n5);background:var(--s0);border-bottom:1px solid var(--s2)}
tbody td{padding:12px 16px;font-size:13px;border-bottom:1px solid var(--s1)}
tbody tr:hover{background:var(--s0)}
.tracking-code{font-family:'Courier New',monospace;font-size:12px;color:var(--n5)}

/* Nav */
.nav{position:fixed;top:0;left:0;right:0;z-index:100;padding:0 48px;height:64px;display:flex;align-items:center;justify-content:space-between;background:#fff;border-bottom:1px solid var(--s2)}
.nav-logo{display:flex;align-items:center}
.nav-logo-img{height:40px;display:block}
.dot{width:8px;height:8px;border-radius:50%;background:var(--g);display:inline-block}
.nav-links{display:flex;gap:32px}.nav-links a{color:var(--n5);font-size:14px;font-weight:500;transition:color .2s}.nav-links a:hover{color:var(--n)}
.nav-btns{display:flex;align-items:center;gap:12px}

/* Hero */
.hero{padding:128px 20px 48px;background:linear-gradient(rgba(15,23,42,.72),rgba(15,23,42,.72)),url('/static/hero-bg.webp') center/cover;background-color:#0F172A;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;color:#fff}
.hero h1{font-size:clamp(26px,5vw,46px);font-weight:800;margin-bottom:12px;letter-spacing:-.5px}
.hero p{font-size:clamp(13px,2vw,16px);color:var(--s3);max-width:560px;margin-bottom:28px;padding:0 8px}

/* Calc */
.calc-card{background:#fff;border-radius:16px;padding:clamp(16px,3vw,32px);width:calc(100% - 40px);max-width:1060px;box-shadow:0 8px 30px rgba(0,0,0,.12);color:var(--n);text-align:left;overflow:hidden}
.calc-top-row{display:flex;gap:24px;margin-bottom:16px}
.calc-half{flex:1;min-width:0}
.calc-section-label{font-size:13px;font-weight:700;margin-bottom:10px}
.calc-sub-label{font-size:11px;color:var(--s4);margin-bottom:12px}
.calc-fields-row{display:flex;gap:10px}
.calc-fields-row .field{flex:1;min-width:0}
.calc-divider{width:1px;background:var(--s2);flex-shrink:0}
.calc-dims{display:grid;grid-template-columns:repeat(5,1fr);gap:10px;margin-bottom:16px}
.calc-btn{width:100%;padding:14px;background:var(--g);color:#fff;border:none;border-radius:8px;font-size:15px;font-weight:700;cursor:pointer;font-family:inherit}
.calc-btn:hover{background:var(--gd)}
.result-card{background:var(--n);border-radius:12px;padding:clamp(16px,3vw,28px);color:#fff;text-align:center;margin-top:20px;animation:slideUp .3s}
.result-price{font-size:clamp(32px,6vw,48px);font-weight:800;color:var(--g);margin:8px 0}
.rw-row{display:flex;justify-content:center;gap:28px;margin:12px 0}
.rw-item{text-align:center}.rw-label{font-size:10px;color:var(--s4);text-transform:uppercase}.rw-val{font-size:16px;font-weight:700;margin-top:2px}

/* Sections */
.section{padding:80px 48px}.section-alt{background:var(--s0)}.section-center{text-align:center}
.section h2{font-size:32px;font-weight:800;margin-bottom:8px}
.section .sub{font-size:15px;color:var(--n5);margin-bottom:48px}
.features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;max-width:1000px;margin:0 auto}
.feature-card{padding:32px 24px;border-radius:12px;border:1px solid var(--s2);background:#fff;transition:all .25s;text-align:center;display:flex;flex-direction:column;align-items:center}
.feature-card:hover{box-shadow:0 4px 12px rgba(0,0,0,.08);border-color:var(--g);transform:translateY(-2px)}
.feature-icon{width:56px;height:56px;border-radius:14px;display:flex;align-items:center;justify-content:center;margin-bottom:18px;font-size:26px}
.fi-g{background:var(--gl)}.fi-b{background:var(--bl)}.fi-o{background:var(--ol)}.fi-s{background:var(--s1)}
.feature-card h3{font-size:16px;font-weight:700;margin-bottom:8px}
.feature-card p{font-size:13px;color:var(--n5);line-height:1.6;max-width:260px}

/* Plugin cards */
.plugin-card{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:24px;flex:1;min-width:260px;text-align:left;transition:all .2s}
.plugin-card:hover{transform:translateY(-4px);border-color:rgba(255,255,255,.2)}

/* Steps */
.steps-row{display:flex;align-items:flex-start;justify-content:center;max-width:900px;margin:0 auto;position:relative}
.step{display:flex;flex-direction:column;align-items:center;text-align:center;flex:1;z-index:2}
.step-circle{width:64px;height:64px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:14px;position:relative;font-size:24px}
.step-num{position:absolute;top:-4px;right:-4px;width:22px;height:22px;border-radius:50%;background:var(--g);color:#fff;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center}
.step h4{font-size:14px;font-weight:700;margin-bottom:4px}
.step p{font-size:12px;color:var(--n5);max-width:150px;line-height:1.5}
.steps-line{position:absolute;top:32px;left:12%;right:12%;height:2px;background:var(--s2);z-index:1}

/* Shipper cards */
.shipper-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;max-width:900px;margin:0 auto}
.shipper-card{border-radius:16px;padding:32px 24px;text-align:center;color:#fff;transition:transform .2s}
.shipper-card:hover{transform:translateY(-4px)}
.shipper-card h3{font-size:15px;font-weight:700;margin-bottom:4px}
.shipper-card p{font-size:12px;opacity:.85;line-height:1.5}
.sc-icon{width:56px;height:56px;border-radius:50%;background:rgba(255,255,255,.2);display:flex;align-items:center;justify-content:center;margin:0 auto 14px;font-size:24px}

/* Couriers */
.courier-logos{display:flex;align-items:center;justify-content:center;gap:48px}.courier-logo{font-size:28px;font-weight:900;opacity:.6;transition:opacity .2s;font-style:italic}.courier-logo:hover{opacity:1}

/* Testimonials */
.test-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;max-width:1000px;margin:0 auto}
.test-card{background:#fff;border:1px solid var(--s2);border-radius:12px;padding:24px;text-align:left;transition:all .25s}
.test-card:hover{box-shadow:0 4px 12px rgba(0,0,0,.08);transform:translateY(-2px)}
.test-stars{color:var(--o);margin-bottom:12px}.test-card p{font-size:13px;line-height:1.7;color:var(--n7);margin-bottom:16px}
.test-author{display:flex;align-items:center;gap:10px}
.test-avatar{width:36px;height:36px;border-radius:50%;background:var(--s2);display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;color:var(--n5)}

/* CTA */
.cta{background:var(--n);padding:64px 48px;text-align:center;color:#fff}
.cta h2{font-size:32px;font-weight:800;margin-bottom:8px}.cta p{color:var(--s4);margin-bottom:28px}
.cta-stats{display:flex;justify-content:center;gap:64px;margin-top:40px}
.cta-val{font-size:32px;font-weight:800;color:var(--g)}.cta-lbl{font-size:13px;color:var(--s4);margin-top:2px}

/* Mission */
.mission{background:var(--gl);padding:64px 48px}
.mission-inner{max-width:800px;margin:0 auto}
.mission h2{font-size:26px;font-weight:800;margin-bottom:16px}
.mission p{font-size:14px;color:var(--n7);line-height:1.8;margin-bottom:12px}

/* SEO server-rendered content — visibile per crawler e durante il caricamento della SPA.
   Sostituito da app.js dopo il mount, quindi gli stili sono minimi e self-contained. */
#seo-intro{max-width:900px;margin:0 auto;padding:80px 24px 40px;color:#1f2937;font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;line-height:1.7}
#seo-intro h1{font-size:clamp(28px,4vw,42px);font-weight:800;line-height:1.2;margin:0 0 20px;letter-spacing:-.02em}
#seo-intro h2{font-size:clamp(20px,2.4vw,26px);font-weight:700;margin:36px 0 14px;line-height:1.3}
#seo-intro p{font-size:16px;margin:0 0 14px}
#seo-intro ol,#seo-intro ul{padding-left:22px;margin:0 0 18px}
#seo-intro li{margin-bottom:8px;font-size:16px}
#seo-intro a{color:#10b981;text-decoration:none;font-weight:600}
#seo-intro a:hover{text-decoration:underline}
#seo-intro strong{font-weight:700}

/* Footer */
.footer{background:var(--n);color:var(--s3);padding:0 0 24px}
.footer-newsletter{background:linear-gradient(135deg,#10b981 0%,#059669 100%);padding:40px 48px;margin-bottom:48px}
.footer-newsletter-inner{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1fr 1.2fr;gap:40px;align-items:center}
.footer-newsletter-text h3{color:#fff;font-size:22px;font-weight:800;margin:0 0 6px;letter-spacing:-.01em}
.footer-newsletter-text p{color:rgba(255,255,255,.85);font-size:14px;margin:0;line-height:1.55}
.footer-newsletter-form{display:flex;gap:8px;flex-wrap:wrap;align-items:flex-start;position:relative}
.footer-newsletter-form input[type=email]{flex:1;min-width:220px;padding:14px 18px;border:none;border-radius:999px;background:rgba(255,255,255,.95);font-size:14px;font-family:inherit;color:#0f172a;outline:none;transition:all .15s}
.footer-newsletter-form input[type=email]:focus{background:#fff;box-shadow:0 0 0 3px rgba(255,255,255,.4)}
.footer-newsletter-form input[type=email]::placeholder{color:#94a3b8}
.footer-newsletter-form button{padding:14px 26px;border:none;border-radius:999px;background:#0f172a;color:#fff;font-size:14px;font-weight:700;cursor:pointer;font-family:inherit;transition:all .15s;white-space:nowrap}
.footer-newsletter-form button:hover{background:#1e293b;transform:translateY(-1px)}
.footer-newsletter-form button:disabled{opacity:.6;cursor:not-allowed;transform:none}
.footer-newsletter-msg{position:absolute;top:100%;left:0;right:0;font-size:12px;margin:8px 0 0;padding:0 8px;color:#fff;font-weight:500;min-height:18px}
.footer-newsletter-msg.success{color:#a7f3d0}
.footer-newsletter-msg.error{color:#fecaca}
.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:40px;margin-bottom:36px;padding:0 48px}
.footer-col h4{font-size:15px;font-weight:700;color:#fff;margin-bottom:16px}
.footer-col a{display:block;font-size:13px;color:var(--s4);margin-bottom:8px;cursor:pointer}.footer-col a:hover{color:#fff}
.footer-legal{border-top:1px solid rgba(255,255,255,.08);padding:16px 48px;text-align:center;font-size:11px;color:var(--s4);line-height:1.7}
.footer-bottom{border-top:1px solid rgba(255,255,255,.08);padding:16px 48px 0;display:flex;justify-content:space-between;font-size:12px;color:var(--s4)}

/* Auth */
.auth-bg{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--s0);padding:20px}
.auth-card{width:100%;max-width:460px;background:#fff;border-radius:16px;padding:40px;box-shadow:0 8px 30px rgba(0,0,0,.12)}
.auth-card.wide{max-width:560px}
.auth-header{text-align:center;margin-bottom:28px}
.auth-header h2{font-size:24px;font-weight:800;margin-bottom:4px}.auth-header p{color:var(--n5);font-size:14px}
.auth-footer{text-align:center;margin-top:18px;font-size:14px;color:var(--n5)}
.auth-footer a{color:var(--g);font-weight:600}
.error-msg{padding:10px 14px;background:var(--rl);color:var(--r);border-radius:8px;font-size:13px;margin-bottom:14px}
.divider{height:1px;background:var(--s2);margin:14px 0}

/* Dashboard */
.dash{display:flex;min-height:100vh}
.sidebar{width:256px;background:var(--n);color:#fff;padding:20px 14px;display:flex;flex-direction:column}
.sidebar-logo{font-size:17px;font-weight:800;display:flex;align-items:center;gap:8px;padding:0 8px 20px;border-bottom:1px solid rgba(255,255,255,.06);margin-bottom:12px}
.sidebar-section{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:var(--n5);padding:14px 8px 6px}
.sb-item{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;color:var(--s4);transition:all .15s;margin-bottom:1px}
.sb-item:hover{background:rgba(255,255,255,.05);color:#fff}.sb-item.active{background:rgba(16,185,129,.12);color:var(--g)}
.sb-spacer{flex:1}
.sb-user{padding:14px 8px;border-top:1px solid rgba(255,255,255,.06);margin-top:8px}
.sb-user-name{font-size:14px;font-weight:600}.sb-user-email{font-size:11px;color:var(--n5);margin-top:2px}
.main-content{flex:1;padding:28px 32px;overflow-y:auto;background:var(--s0)}
.page-hdr{margin-bottom:24px}.page-hdr h1{font-size:24px;font-weight:800}.page-hdr p{color:var(--n5);font-size:14px;margin-top:2px}

/* Modal */
.modal-overlay{position:fixed;inset:0;background:rgba(15,23,42,.5);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:200;padding:20px}
.modal{background:#fff;border-radius:16px;width:100%;max-width:640px;max-height:85vh;overflow-y:auto;padding:28px;animation:fadeIn .2s}
.modal-hdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}
.modal-hdr h2{font-size:18px;font-weight:800}
.modal-close{width:32px;height:32px;border:none;background:var(--s1);border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:16px}
.modal-close:hover{background:var(--s2)}
.detail-route{display:flex;gap:16px;margin-bottom:18px;padding:18px;background:var(--s0);border-radius:12px}
.detail-route-pt{flex:1}
.detail-route-pt h4{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--n5);margin-bottom:5px}
.detail-arrow{display:flex;align-items:center;color:var(--g);font-size:20px;font-weight:700}
.detail-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px;margin-bottom:16px}
.detail-block h4{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--n5);margin-bottom:3px}

/* Price box */
.price-box{background:var(--n);border-radius:12px;padding:28px;color:#fff;text-align:center;margin-top:18px;animation:slideUp .3s}
.price-box .total{font-size:44px;font-weight:800;color:var(--g);margin:6px 0}
.step-badge{width:26px;height:26px;background:var(--g);color:#fff;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:12px;font-weight:700}

/* Tariff */
.tariff-tbl{width:100%;border-collapse:collapse;font-size:13px}
.tariff-tbl th{padding:10px 12px;background:var(--n);color:#fff;text-align:center;font-size:11px;font-weight:600}
.tariff-tbl th:first-child{text-align:left;border-radius:8px 0 0 0}.tariff-tbl th:last-child{border-radius:0 8px 0 0}
.tariff-tbl td{padding:10px 12px;text-align:center;border-bottom:1px solid var(--s1)}.tariff-tbl td:first-child{text-align:left;font-weight:600}
.tariff-tbl tr:hover td{background:var(--s0)}

/* Toast */
.toast{position:fixed;bottom:24px;right:24px;background:var(--n);color:#fff;padding:14px 22px;border-radius:8px;font-size:14px;z-index:300;display:flex;align-items:center;gap:10px;box-shadow:0 8px 30px rgba(0,0,0,.12);animation:slideUp .3s;border-left:4px solid var(--g)}
.toast.error{border-left-color:var(--r)}
.spinner{width:32px;height:32px;border:3px solid var(--s2);border-top:3px solid var(--g);border-radius:50%;animation:spin .8s linear infinite;margin:60px auto}
@keyframes spin{to{transform:rotate(360deg)}}

/* Admin sidebar override */
.admin-sb{background:#111827}.admin-sb .sb-item.active{background:rgba(59,130,246,.12);color:#60a5fa}

/* Tbl container */
.tbl-container{background:#fff;border:1px solid var(--s2);border-radius:12px;overflow:hidden}
.tbl-header{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--s2)}
.tbl-header h3{font-size:15px;font-weight:700}
.tbl-search{display:flex;align-items:center;gap:6px;background:var(--s0);border:1px solid var(--s2);border-radius:8px;padding:6px 10px}
.tbl-search input{border:none;background:none;outline:none;font-size:13px;font-family:inherit;width:180px}

@media(max-width:768px){
  .nav{padding:0 12px;height:56px;display:grid;grid-template-columns:44px 1fr 44px;align-items:center;background:#fff;border-bottom:1px solid var(--s2)}
  .nav-logo{justify-self:center;grid-column:2}
  .nav-logo-img{height:44px}
  .nav-links{display:none}
  .nav-btns{display:none}
  .nav-mobile-toggle{display:flex!important;grid-column:1;justify-self:start;order:0}
  .hero{padding:104px 16px 36px}
  .calc-card{padding:16px;border-radius:12px;width:calc(100% - 24px)}
  .calc-top-row{flex-direction:column;gap:16px}
  .calc-divider{width:100%;height:1px}
  .calc-fields-row{gap:8px}
  .calc-dims{grid-template-columns:1fr 1fr;gap:8px}
  .calc-dims .field:first-child{grid-column:span 2}
  .calc-btn{padding:12px;font-size:14px}
  .result-card{padding:20px}
  .result-price{font-size:36px}
  .rw-row{flex-direction:column;gap:8px}
  .section{padding:40px 16px}
  .section h2{font-size:24px}
  .features-grid{display:flex;flex-direction:row;flex-wrap:nowrap;gap:16px;overflow-x:auto;padding:8px 16px 12px;-webkit-overflow-scrolling:touch;scroll-snap-type:x mandatory;max-width:none}
  .features-grid::-webkit-scrollbar{display:none}
  .feature-card{flex:0 0 260px;min-width:260px;scroll-snap-align:center;padding:24px 20px}
  .test-grid{display:flex;flex-direction:row;flex-wrap:nowrap;gap:16px;overflow-x:auto;padding:8px 16px 12px;-webkit-overflow-scrolling:touch;scroll-snap-type:x mandatory;max-width:none}
  .test-grid::-webkit-scrollbar{display:none}
  .test-card{flex:0 0 280px;min-width:280px;scroll-snap-align:center}
  .shipper-grid{grid-template-columns:1fr 1fr}
  .steps-row{flex-direction:row;flex-wrap:nowrap;gap:16px;justify-content:flex-start;overflow-x:auto;padding:12px 16px;-webkit-overflow-scrolling:touch;scroll-snap-type:x mandatory}
  .steps-row::-webkit-scrollbar{display:none}
  .steps-line{display:none}
  .step{flex:0 0 140px;min-width:140px;scroll-snap-align:center}
  .step-circle{width:52px;height:52px;font-size:20px}
  .step h4{font-size:13px}.step p{font-size:11px;max-width:130px}
  .cta{padding:40px 16px}
  .cta-stats{flex-direction:row;gap:0;justify-content:center}
  .cta-stats>div{flex:1;text-align:center}
  .cta-val{font-size:22px}
  .mission{padding:40px 16px}
  .footer{padding:0 0 16px}
  .footer-newsletter{padding:28px 16px;margin-bottom:32px}
  .footer-newsletter-inner{grid-template-columns:1fr;gap:20px;text-align:center}
  .footer-newsletter-form{justify-content:center}
  .footer-newsletter-msg{position:static;text-align:center;margin-top:10px}
  .footer-grid{grid-template-columns:1fr 1fr;gap:20px;padding:0 16px}
  .footer-legal{padding:16px}
  .footer-bottom{padding:16px 16px 0}
  .courier-logos{gap:24px}
  .courier-logo{font-size:22px}
  .stats-grid{grid-template-columns:1fr 1fr;gap:8px}
  .plugin-cards{grid-template-columns:1fr!important}
  .stat-val{font-size:22px}
  .form-grid{grid-template-columns:1fr}
  .form-grid-3{grid-template-columns:1fr}
  .detail-grid{grid-template-columns:1fr 1fr}
  .sidebar{position:fixed;left:-260px;top:0;bottom:0;width:256px;z-index:9999;transition:left .3s ease;box-shadow:4px 0 20px rgba(0,0,0,.3)}
  .sidebar.sb-open{left:0}
  .sb-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:9998}
  .sb-overlay.active{display:block}
  .sb-hamburger{display:flex!important}
  .main-content{margin-left:0!important}
  .main-content{padding:16px}
  .tbl-search input{width:120px}
  .pay-layout{grid-template-columns:1fr}
  .pay-summary{position:static}
  .wizard-steps{flex-wrap:wrap;gap:4px;padding:0 8px}
  .wz-step span:not(.wz-dot){display:none}
  .wz-line{width:24px;margin:0 4px}
  .frontend-content{padding:72px 16px 40px}
  .addr-grid{grid-template-columns:1fr}
  .carrier-info{flex-wrap:wrap;gap:8px}
  .rate-card{flex-wrap:wrap;gap:8px;padding:14px}
  .rate-price{font-size:18px}
  .pickup-grid{grid-template-columns:1fr}
  .date-grid{grid-template-columns:repeat(5,1fr)}
  .time-grid{grid-template-columns:repeat(3,1fr)}
  .confirm-section{padding:14px}
  .agc-header{padding:12px 14px}
  .auth-gate-card .agc-body{padding:0 14px 14px}
  .nav-user-name{display:none}
  .modal{padding:20px;margin:10px;max-height:90vh}
  .detail-route{flex-direction:column;gap:8px}
  .detail-route .detail-arrow{transform:rotate(90deg)}
  table{display:block;overflow-x:auto}
  .seo-section{padding:40px 16px}
  .seo-section h1{font-size:20px}.seo-section h2{font-size:18px}.seo-section h3{font-size:16px}
  .ci-item > div{grid-template-columns:1fr 1fr!important}
  .ci-item > div > .field:first-child{grid-column:span 2}
  .wz-addr-layout{grid-template-columns:1fr!important}
  .pkg-fields-grid{grid-template-columns:1fr 1fr!important}
  .pkg-fields-grid .field:first-child{grid-column:span 2}
  .plugin-cards{flex-direction:column;align-items:stretch}
  .plugin-card{min-width:auto;max-width:none}
  .tbl-container{overflow-x:auto;-webkit-overflow-scrolling:touch}
  .tbl-container table{min-width:560px}
  /* Prevent overflow from any absolute children */
  html,body{overflow-x:hidden;max-width:100vw}
  /* Page headers */
  .page-hdr h1{font-size:22px;line-height:1.2}
  .page-hdr p{font-size:13px}
  /* Buttons minimum tap target (iOS HIG suggests 44px) */
  .btn{min-height:40px;padding:10px 16px}
  .btn-sm{min-height:36px}
  /* Payment method cards: bigger tap target + more breathing room on mobile */
  .pay-methods{flex-direction:column;gap:10px;margin-bottom:24px}
  .pay-method{padding:18px 16px;font-size:14px;display:flex;align-items:center;gap:12px;text-align:left}
  .pay-method .pm-icon{font-size:26px;margin-bottom:0;margin-right:4px}
  /* Modal on mobile: full width with sensible margins */
  .modal-overlay{padding:12px}
  .modal{border-radius:12px;width:100%;margin:0;max-height:calc(100vh - 24px)}
  /* Date grid: wider cells, horizontal scroll if too cramped */
  .date-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:6px}
  .date-cell{padding:10px 4px;font-size:12px}
  /* Wizard steps numeric only */
  .wizard-steps{padding:0 4px;margin-bottom:20px}
  .wz-dot{width:28px;height:28px;font-size:12px}
  /* Hero stats denser */
  .hero h1{line-height:1.15}
  /* Addr card full-width */
  .wz-addr-layout{grid-template-columns:1fr!important}
  .wz-addr-layout > :last-child{order:-1}
  /* Legal pages sidebar becomes collapsible summary */
  .legal-toc-layout{grid-template-columns:1fr!important;gap:16px}
  /* Input font-size 16px to prevent iOS zoom on focus */
  .field input,.field select,.field textarea,input,select,textarea{font-size:16px!important}
  .field label{font-size:11px}
}

/* Very small phones (< 480px) */
@media(max-width:480px){
  .nav{padding:0 8px}
  .nav-logo-img{height:38px}
  .hero{padding:92px 12px 32px}
  .hero h1{font-size:22px}
  .section{padding:32px 12px}
  .section h2{font-size:20px}
  .section .sub{font-size:13px;margin-bottom:28px}
  .shipper-grid{grid-template-columns:1fr}
  .feature-card{flex:0 0 240px;min-width:240px}
  .stats-grid{grid-template-columns:1fr 1fr;gap:6px}
  .stat-card{padding:12px 14px}
  .stat-val{font-size:20px}
  .step{flex:0 0 100%;max-width:100%}
  .cta-stats{flex-direction:row;gap:0;justify-content:center}
  .cta-stats>div{flex:1;text-align:center}
  .footer-grid{grid-template-columns:1fr;gap:16px;padding:0 12px}
  .footer{padding:0 0 12px}
  .footer-newsletter{padding:24px 12px;margin-bottom:24px}
  .footer-newsletter-text h3{font-size:18px}
  .footer-legal{padding:12px}
  .footer-bottom{padding:12px 12px 0}
  .legal-content{padding:0 4px}
  .page-hdr h1{font-size:20px}
  .cookie-banner{padding:14px 12px}
  .cookie-banner-content{gap:10px}
  .cookie-banner-actions{width:100%}
  .cookie-banner-actions .btn{flex:1;min-width:0;padding:8px 6px;font-size:11px}
  /* Fields & forms */
  .calc-card{padding:12px}
  .calc-dims{grid-template-columns:1fr 1fr}
  .date-grid{grid-template-columns:repeat(3,1fr)}
  .time-grid{grid-template-columns:repeat(2,1fr)}
  /* Rate card vertical */
  .rate-card{flex-direction:column;align-items:flex-start}
  .rate-price{text-align:left;min-width:0}
  /* Admin tables compact */
  thead th,tbody td{padding:8px 10px;font-size:12px}
}

/* ═══ WIZARD CONTAINER ═══ */
.wizard-container{max-width:900px;margin:0 auto}

/* ═══ WIZARD STEPPER ═══ */
.wizard-steps{display:flex;align-items:center;justify-content:center;gap:0;margin-bottom:32px;padding:0 20px}
.wz-step{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:var(--s4);position:relative}
.wz-step.active{color:var(--g)}.wz-step.done{color:var(--g)}
.wz-dot{width:32px;height:32px;border-radius:50%;border:2px solid var(--s2);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;transition:all .3s}
.wz-step.active .wz-dot{background:var(--g);border-color:var(--g);color:#fff}
.wz-step.done .wz-dot{background:var(--g);border-color:var(--g);color:#fff}
.wz-line{width:60px;height:2px;background:var(--s2);margin:0 8px}
.wz-line.done{background:var(--g)}

/* ═══ ADDRESS CARDS ═══ */
.addr-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:16px}
.addr-card{border:2px solid var(--s2);border-radius:12px;padding:16px;cursor:pointer;transition:all .2s;position:relative}
.addr-card:hover{border-color:var(--s3);background:var(--s0)}
.addr-card.selected{border-color:var(--g);background:rgba(16,185,129,.04)}
.addr-card .addr-label{display:inline-block;padding:2px 8px;border-radius:4px;font-size:10px;font-weight:700;text-transform:uppercase;background:var(--s1);color:var(--n5);margin-bottom:8px}
.addr-card .addr-label.default{background:var(--gl);color:var(--gd)}
.addr-card .addr-name{font-size:14px;font-weight:700;margin-bottom:4px}
.addr-card .addr-detail{font-size:12px;color:var(--n5);line-height:1.5}
.addr-card .addr-check{position:absolute;top:12px;right:12px;width:20px;height:20px;border-radius:50%;border:2px solid var(--s2);display:flex;align-items:center;justify-content:center;font-size:11px}
.addr-card.selected .addr-check{background:var(--g);border-color:var(--g);color:#fff}

/* ═══ CARRIER CARDS ═══ */
.carrier-info{display:flex;gap:16px;margin-bottom:20px;padding:16px;background:var(--s0);border-radius:12px;font-size:13px}
.carrier-info-item{text-align:center;flex:1}
.carrier-info-item .ci-label{font-size:10px;color:var(--s4);text-transform:uppercase;margin-bottom:2px}
.carrier-info-item .ci-val{font-weight:700}
.rate-card{border:2px solid var(--s2);border-radius:12px;padding:20px;display:flex;align-items:center;gap:16px;margin-bottom:12px;cursor:pointer;transition:all .2s}
.rate-card:hover{border-color:var(--s3);background:var(--s0)}
.rate-card.selected{border-color:var(--g);background:rgba(16,185,129,.04)}
.rate-logo{width:56px;height:56px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-weight:900;font-size:16px;background:var(--s1);flex-shrink:0}
.rate-logo.ups{background:#FFD700;color:#351C15}.rate-logo.dhl{background:#FC0;color:#D40511}
.rate-logo.fedex{background:#E8E0F0;color:#4D148C}.rate-logo.gls{background:#E0F0E8;color:#1B5E20}
.rate-body{flex:1}
.rate-name{font-size:15px;font-weight:700;display:flex;align-items:center;gap:8px}
.rate-name .rate-rating{font-size:12px;color:var(--o)}
.rate-meta{font-size:12px;color:var(--n5);margin-top:2px}
.rate-save{display:inline-block;padding:2px 8px;border-radius:4px;font-size:11px;font-weight:700;background:var(--gl);color:var(--gd);margin-left:8px}
.rate-price{font-size:22px;font-weight:800;color:var(--g);text-align:right;flex-shrink:0;min-width:80px}
.rate-check{width:24px;height:24px;border-radius:50%;border:2px solid var(--s2);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.rate-card.selected .rate-check{background:var(--g);border-color:var(--g);color:#fff}
.rate-badges{display:flex;gap:12px;margin-top:16px}
.rate-badge-card{flex:1;padding:12px;border:1px solid var(--s2);border-radius:8px;text-align:center}
.rate-badge-card h4{font-size:13px;font-weight:700;margin-bottom:2px}
.rate-badge-card p{font-size:11px;color:var(--n5)}

/* ═══ CONFIRM SUMMARY ═══ */
.confirm-section{border:1px solid var(--s2);border-radius:12px;padding:20px;margin-bottom:16px}
.confirm-section h3{font-size:14px;font-weight:700;margin-bottom:12px;display:flex;align-items:center;gap:8px}
.confirm-pair{display:flex;justify-content:space-between;font-size:13px;padding:4px 0}
.confirm-pair .cp-label{color:var(--n5)}.confirm-pair .cp-val{font-weight:600}

/* ═══ PAYMENT ═══ */
.pay-layout{display:grid;grid-template-columns:1fr 340px;gap:24px}
.pay-summary{background:var(--n);border-radius:12px;padding:24px;color:#fff;height:fit-content;position:sticky;top:20px}
.pay-summary h3{font-size:15px;font-weight:700;margin-bottom:16px}
.pay-row{display:flex;justify-content:space-between;font-size:13px;padding:6px 0;border-bottom:1px solid rgba(255,255,255,.08)}
.pay-row:last-child{border:none}.pay-row .pr-label{color:var(--s4)}.pay-row .pr-val{font-weight:600}
.pay-total{margin-top:12px;padding-top:12px;border-top:1px solid rgba(255,255,255,.15);display:flex;justify-content:space-between;font-size:18px;font-weight:800}
.pay-total .pt-val{color:var(--g)}
.pay-methods{display:flex;gap:8px;margin-bottom:20px}
.pay-method{flex:1;padding:12px;border:2px solid var(--s2);border-radius:8px;text-align:center;cursor:pointer;font-size:13px;font-weight:600;transition:all .2s}
.pay-method:hover{border-color:var(--s3)}.pay-method.active{border-color:var(--g);background:rgba(16,185,129,.04)}
.pay-method .pm-icon{font-size:24px;margin-bottom:4px}
.pay-method.pm-disabled{opacity:.55;cursor:not-allowed;background:var(--s0);border-color:var(--s2);color:var(--s4)}
.pay-method.pm-disabled:hover{border-color:var(--s2)}

/* ═══ SUCCESS ═══ */
.success-page{text-align:center;padding:60px 20px}
.success-circle{width:100px;height:100px;border-radius:50%;background:var(--gl);color:var(--g);display:flex;align-items:center;justify-content:center;font-size:48px;margin:0 auto 24px;animation:scaleIn .5s ease}
@keyframes scaleIn{from{transform:scale(0)}to{transform:scale(1)}}
.success-page h2{font-size:24px;font-weight:800;margin-bottom:8px}
.success-page p{color:var(--n5);margin-bottom:24px}

/* ═══ PICKUP OPTIONS ═══ */
.pickup-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:12px}
.pickup-opt{border:2px solid var(--s2);border-radius:12px;padding:16px;cursor:pointer;transition:all .2s;text-align:center}
.pickup-opt:hover{border-color:var(--s3)}.pickup-opt.active{border-color:var(--g);background:rgba(16,185,129,.04)}
.pickup-opt .po-icon{font-size:28px;margin-bottom:6px}
.pickup-opt h4{font-size:13px;font-weight:700;margin-bottom:2px}
.pickup-opt p{font-size:11px;color:var(--n5)}

/* ═══ DATE/TIME PICKER ═══ */
.date-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px;margin-top:8px}
.date-cell{padding:8px 4px;border-radius:8px;text-align:center;cursor:pointer;font-size:12px;font-weight:600;transition:all .15s;border:1px solid transparent}
.date-cell:hover{background:var(--s0);border-color:var(--s2)}
.date-cell.selected{background:var(--g);color:#fff;border-color:var(--g)}
.date-cell.today{border-color:var(--g)}
.date-cell .dc-day{font-size:10px;color:var(--s4);font-weight:500}
.date-cell.selected .dc-day{color:rgba(255,255,255,.7)}
.time-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;margin-top:8px}
.time-cell{padding:8px;border-radius:8px;text-align:center;cursor:pointer;font-size:13px;font-weight:600;border:1px solid var(--s2);transition:all .15s}
.time-cell:hover{border-color:var(--s3);background:var(--s0)}
.time-cell.selected{background:var(--g);color:#fff;border-color:var(--g)}

/* ═══ TRACKING TIMELINE ═══ */
.timeline{position:relative;padding-left:32px}
.timeline::before{content:'';position:absolute;left:11px;top:8px;bottom:8px;width:2px;background:var(--s2)}
.tl-item{position:relative;padding-bottom:24px}
.tl-item:last-child{padding-bottom:0}
.tl-dot{position:absolute;left:-32px;top:2px;width:22px;height:22px;border-radius:50%;border:2px solid var(--s2);background:#fff;display:flex;align-items:center;justify-content:center;font-size:10px}
.tl-item.active .tl-dot{background:var(--g);border-color:var(--g);color:#fff}
.tl-item.done .tl-dot{background:var(--g);border-color:var(--g);color:#fff}
.tl-title{font-size:14px;font-weight:700;margin-bottom:2px}
.tl-desc{font-size:12px;color:var(--n5)}
.tl-time{font-size:11px;color:var(--s4);margin-top:2px}

/* ═══ NAV USER (logged in) ═══ */
.nav-user{display:flex;align-items:center;gap:8px}
.nav-user-avatar{width:32px;height:32px;border-radius:50%;background:rgba(16,185,129,.3);color:#fff;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700}
.nav-user-name{color:var(--n);font-size:13px;font-weight:600;max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.nav-active{color:var(--n)!important;position:relative}
.nav-active::after{content:'';position:absolute;bottom:-4px;left:0;right:0;height:2px;background:var(--g);border-radius:1px}

/* ═══ FRONTEND CONTENT (pages with top nav) ═══ */
.frontend-content{padding:96px 48px 60px;min-height:calc(100vh - 64px)}

/* ═══ AUTH GATE (checkout) ═══ */
.auth-gate-opts{display:flex;flex-direction:column;gap:12px}
.auth-gate-card{border:2px solid var(--s2);border-radius:12px;overflow:hidden;transition:border-color .2s}
.auth-gate-card:hover{border-color:var(--s3)}
.agc-header{display:flex;align-items:center;gap:14px;padding:16px 20px;cursor:pointer;transition:background .15s}
.agc-header:hover{background:var(--s0)}
.agc-icon{font-size:28px;flex-shrink:0}
.agc-header h4{font-size:14px;font-weight:700;margin-bottom:2px}
.agc-header p{font-size:12px;color:var(--n5)}
.agc-arrow{margin-left:auto;font-size:20px;color:var(--s4);transition:transform .2s}
.agc-body{padding:0 20px 20px;animation:fadeIn .2s}
.agc-body.hidden{display:none}

/* ═══ FIELD VALIDATION ═══ */
.field.field-error input,.field.field-error select{border-color:var(--r)!important;box-shadow:0 0 0 3px rgba(239,68,68,.12)!important;animation:shake .3s ease}
.field.field-error label{color:var(--r)!important}
.field-error-msg{font-size:11px;color:var(--r);margin-top:2px;font-weight:500}
@keyframes shake{0%,100%{transform:translateX(0)}20%,60%{transform:translateX(-4px)}40%,80%{transform:translateX(4px)}}

/* ═══ NAV DROPDOWN ═══ */
.nav-user-wrap{position:relative}
.nav-user{cursor:pointer}
.nav-user-arrow{color:var(--s4);font-size:10px;margin-left:2px}
.nav-dropdown{position:absolute;top:calc(100% + 8px);right:0;width:260px;background:#fff;border-radius:12px;box-shadow:0 8px 30px rgba(0,0,0,.15);border:1px solid var(--s2);z-index:200;animation:fadeIn .15s;overflow:hidden}
.nav-dropdown.hidden{display:none}
.nd-header{display:flex;align-items:center;gap:10px;padding:16px}
.nd-avatar{width:40px;height:40px;border-radius:50%;background:var(--gl);color:var(--g);display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:700;flex-shrink:0}
.nd-name{font-size:14px;font-weight:700;color:var(--n)}.nd-email{font-size:12px;color:var(--n5)}
.nd-divider{height:1px;background:var(--s2);margin:0}
.nd-item{display:flex;align-items:center;gap:10px;padding:10px 16px;font-size:13px;font-weight:500;color:var(--n5);cursor:pointer;transition:background .1s}
.nd-item:hover{background:var(--s0);color:var(--n)}
.nd-logout{color:var(--r)}.nd-logout:hover{background:var(--rl)}

/* ═══ SETTINGS LAYOUT ═══ */
.settings-layout{display:grid;grid-template-columns:260px 1fr;gap:24px}
.settings-sidebar{display:flex;flex-direction:column;gap:2px}
.ss-profile-card{background:#fff;border:1px solid var(--s2);border-radius:12px;padding:20px;text-align:center;margin-bottom:12px}
.ss-avatar{width:56px;height:56px;border-radius:50%;background:var(--gl);color:var(--g);display:flex;align-items:center;justify-content:center;font-size:22px;font-weight:800;margin:0 auto 10px}
.ss-name{font-size:15px;font-weight:700}.ss-email{font-size:12px;color:var(--n5);margin-top:2px}
.ss-meta{font-size:11px;color:var(--s4);margin-top:6px}
.ss-tab{display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:8px;font-size:13px;font-weight:500;color:var(--n5);cursor:pointer;transition:all .15s}
.ss-tab:hover{background:var(--s0);color:var(--n)}
.ss-tab.active{background:rgba(16,185,129,.08);color:var(--g);font-weight:600}
.settings-content{min-height:400px}

/* ═══ PAYMENT METHOD CARD ICON ═══ */
.pm-card-icon{width:48px;height:48px;border-radius:8px;background:var(--s1);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:900;color:var(--n5);flex-shrink:0}

/* ═══ TOGGLE SWITCH ═══ */
.toggle{position:relative;display:inline-block;width:48px;height:26px;flex-shrink:0}
.toggle input{opacity:0;width:0;height:0}
.toggle-slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background:var(--s2);border-radius:26px;transition:.2s}
.toggle-slider::before{content:'';position:absolute;height:20px;width:20px;left:3px;bottom:3px;background:#fff;border-radius:50%;transition:.2s}
.toggle input:checked + .toggle-slider{background:var(--g)}
.toggle input:checked + .toggle-slider::before{transform:translateX(22px)}

@media(max-width:768px){
  .settings-layout{grid-template-columns:1fr;gap:0}
  .settings-sidebar{display:none}
  .settings-mobile-select{display:block!important}
  .ss-profile-card{display:none}
  .nav-dropdown{width:calc(100vw - 24px);right:-12px}
  /* Unify card spacing inside settings/profile with the rest of the system (wizard pattern) */
  .settings-content .card{padding:18px 16px;margin-bottom:12px}
  .settings-content h2{font-size:18px;margin-bottom:4px}
  .settings-content > .fade-in > p{font-size:13px;margin-bottom:18px}
}

/* ═══ STRIPE CARD ELEMENT ═══ */
.StripeElement{padding:12px;border:1.5px solid var(--s2);border-radius:8px;background:#fff;transition:border-color .2s}
.StripeElement--focus{border-color:var(--g);box-shadow:0 0 0 3px rgba(16,185,129,.1)}
.StripeElement--invalid{border-color:var(--r)}

/* ═══ MULTI-PACKAGE ═══ */
.pkg-row{position:relative;transition:all .2s}
.pkg-row:hover{border-color:var(--g)}
.pkg-remove{position:absolute;top:8px;right:8px;width:24px;height:24px;border-radius:50%;border:none;background:var(--rl);color:var(--r);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:12px;transition:all .15s;z-index:2}
.pkg-remove:hover{background:var(--r);color:#fff}
@media(max-width:768px){
  .pkg-row .form-grid-3,.pkg-row > div[style*="grid-template-columns:1fr 1fr 1fr 1fr 1fr"]{grid-template-columns:1fr 1fr!important}
}

/* ═══ GUIDA PAGE ═══ */

/* Timeline dettagliata */
.guida-timeline{position:relative;padding-left:48px}
.guida-timeline::before{content:'';position:absolute;left:19px;top:24px;bottom:24px;width:3px;background:linear-gradient(var(--g),var(--gd));border-radius:3px}
.guida-tl-item{position:relative;margin-bottom:40px}
.guida-tl-item:last-child{margin-bottom:0}
.guida-tl-num{position:absolute;left:-48px;top:0;width:40px;height:40px;border-radius:50%;background:var(--g);color:#fff;font-size:16px;font-weight:800;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px rgba(16,185,129,.3)}
.guida-tl-content{background:#fff;border:1px solid var(--s2);border-radius:12px;padding:24px 28px}
.guida-tl-content h3{font-size:18px;font-weight:700;margin-bottom:10px;color:var(--n)}
.guida-tl-content p{font-size:14px;color:var(--n5);line-height:1.7;margin-bottom:8px}
.guida-tl-content p:last-child{margin-bottom:0}
.guida-tl-tip{background:var(--gl);border-radius:8px;padding:12px 16px;font-size:13px;line-height:1.6;margin-top:12px;color:var(--n7)}
.guida-list{list-style:none;padding:0;margin:8px 0}
.guida-list li{padding:4px 0 4px 20px;position:relative;font-size:14px;color:var(--n5);line-height:1.6}
.guida-list li::before{content:'•';position:absolute;left:0;color:var(--g);font-weight:700}

/* FAQ */
.guida-faq{max-width:700px;margin:0 auto}
.guida-faq-item{border:1px solid var(--s2);border-radius:10px;margin-bottom:8px;overflow:hidden;transition:border-color .2s}
.guida-faq-item:hover{border-color:var(--s3)}
.guida-faq-q{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;cursor:pointer;font-size:14px;font-weight:600;transition:background .15s}
.guida-faq-q:hover{background:var(--s0)}
.guida-faq-arrow{font-size:20px;color:var(--s4);transition:transform .2s}
.guida-faq-item.open .guida-faq-arrow{transform:rotate(90deg);color:var(--g)}
.guida-faq-a{max-height:0;overflow:hidden;transition:max-height .3s ease}
.guida-faq-item.open .guida-faq-a{max-height:300px}
.guida-faq-a p{padding:0 20px 16px;font-size:13px;color:var(--n5);line-height:1.7}

@media(max-width:768px){
  .guida-timeline{padding-left:40px}
  .guida-tl-num{left:-40px;width:32px;height:32px;font-size:14px}
  .guida-timeline::before{left:15px}
  .guida-tl-content{padding:16px 18px}
  .guida-tl-content h3{font-size:16px}
}

/* ═══ LEGAL PAGES ═══ */
.legal-layout{display:grid;grid-template-columns:240px 1fr;gap:36px;max-width:1100px;margin:0 auto}
.legal-sidebar{position:sticky;top:80px;height:fit-content}
.legal-toc{background:#fff;border:1px solid var(--s2);border-radius:12px;padding:20px;display:flex;flex-direction:column;gap:2px}
.legal-toc h4{font-size:13px;font-weight:700;margin-bottom:12px;color:var(--n)}
.legal-toc-item{display:block;padding:6px 10px;border-radius:6px;font-size:12px;color:var(--n5);cursor:pointer;transition:all .15s;text-decoration:none}
.legal-toc-item:hover{background:var(--s0);color:var(--n)}
.legal-content{max-width:760px}
.legal-article{background:#fff;border:1px solid var(--s2);border-radius:12px;padding:28px 32px;margin-bottom:16px;scroll-margin-top:80px}
.legal-article h3{font-size:17px;font-weight:700;margin-bottom:14px;display:flex;align-items:center;gap:10px;color:var(--n)}
.legal-num{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;background:var(--g);color:#fff;font-size:13px;font-weight:700;flex-shrink:0}
.legal-article p{font-size:14px;color:var(--n5);line-height:1.8;margin-bottom:10px}
.legal-article p:last-child{margin-bottom:0}
.legal-article strong{color:var(--n)}
.legal-article ul{margin:8px 0 12px}
.legal-article a{color:var(--g);font-weight:600}

@media(max-width:768px){
  .legal-layout{grid-template-columns:1fr}
  .legal-sidebar{position:static}
  .legal-toc{display:none}
  .legal-article{padding:20px}
}

/* ═══ CHI SIAMO PAGE ═══ */
.about-intro{display:grid;grid-template-columns:1.2fr 1fr;gap:48px;max-width:1100px;margin:0 auto;align-items:center}
.about-intro-text h2{font-size:clamp(24px,3vw,32px);font-weight:800;margin-bottom:16px}
.about-intro-text p{font-size:14px;color:var(--n5);line-height:1.8;margin-bottom:12px}
.about-intro-text strong{color:var(--n)}
.about-stat-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.about-stat{background:#fff;border:1px solid var(--s2);border-radius:14px;padding:24px 20px;text-align:center;transition:all .25s}
.about-stat:hover{border-color:var(--g);transform:translateY(-3px);box-shadow:0 6px 20px rgba(0,0,0,.06)}
.about-stat-val{font-size:clamp(24px,3vw,32px);font-weight:800;color:var(--g);margin-bottom:4px}
.about-stat-lbl{font-size:12px;color:var(--n5);font-weight:600}

/* Partners */
.about-partners{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;max-width:1000px;margin:0 auto}
.about-partner-card{background:#fff;border:1px solid var(--s2);border-radius:14px;padding:28px 20px;text-align:center;transition:all .25s}
.about-partner-card:hover{transform:translateY(-3px);box-shadow:0 6px 20px rgba(0,0,0,.06);border-color:var(--g)}
.about-partner-logo{width:64px;height:64px;border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:900;font-style:italic;margin:0 auto 14px}
.about-partner-card h4{font-size:16px;font-weight:700;margin-bottom:6px}
.about-partner-card p{font-size:12px;color:var(--n5);line-height:1.5}

/* Business section */
.about-business{display:grid;grid-template-columns:1.3fr 1fr;gap:48px;max-width:1100px;margin:0 auto;align-items:center}
.about-biz-badge{display:inline-block;background:var(--gl);color:var(--gd);padding:4px 12px;border-radius:20px;font-size:12px;font-weight:700;margin-bottom:12px}
.about-biz-content h2{font-size:clamp(22px,3vw,28px);font-weight:800;margin-bottom:12px}
.about-biz-content p{font-size:14px;color:var(--n5);line-height:1.7;margin-bottom:8px}
.about-biz-features{display:flex;flex-direction:column;gap:12px;margin-top:16px}
.about-biz-feat{display:flex;gap:12px;align-items:flex-start;font-size:13px;line-height:1.6}
.about-biz-icon{font-size:22px;flex-shrink:0;margin-top:2px}
.about-biz-visual{display:flex;align-items:center;justify-content:center}
.about-biz-mock{width:100%;max-width:340px;background:#fff;border:1px solid var(--s2);border-radius:16px;padding:24px;display:flex;flex-direction:column;gap:14px;box-shadow:0 8px 30px rgba(0,0,0,.06)}
.about-biz-mock-bar{height:8px;background:var(--s2);border-radius:4px;width:60%}
.about-biz-mock-row{display:flex;gap:12px}
.about-biz-mock-stat{flex:1;border-radius:10px;padding:14px;text-align:center}
.about-biz-mock-chart{height:12px;background:linear-gradient(90deg,var(--g),var(--gd));border-radius:6px;width:80%}

@media(max-width:768px){
  .about-intro{grid-template-columns:1fr}
  .about-stat-grid{grid-template-columns:1fr 1fr}
  .about-partners{grid-template-columns:1fr 1fr}
  .about-business{grid-template-columns:1fr}
  .about-biz-visual{order:-1}
  .about-biz-mock{max-width:280px;margin:0 auto}
  .test-grid{grid-template-columns:1fr}
}

/* ═══ TARIFFE PAGE ═══ */
.tariffe-carriers-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;max-width:800px;margin:0 auto}
.tariffe-carrier-card{background:#fff;border:1px solid var(--s2);border-radius:12px;padding:20px;text-align:center;transition:all .2s}
.tariffe-carrier-card:hover{border-color:var(--g);transform:translateY(-2px)}
.tariffe-carrier-logo{font-size:20px;font-weight:900;font-style:italic;margin-bottom:4px}
.tariffe-carrier-mult{font-size:22px;font-weight:800;color:var(--g);margin-bottom:4px}
.tariffe-carrier-card p{font-size:11px;color:var(--n5)}

.tariffe-zone-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:14px;max-width:1000px;margin:0 auto}
.tariffe-zone-card{background:#fff;border:1px solid var(--s2);border-radius:12px;padding:20px;text-align:center;transition:all .2s}
.tariffe-zone-card:hover{border-color:var(--g);transform:translateY(-2px);box-shadow:0 4px 16px rgba(0,0,0,.06)}
.tariffe-zone-icon{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:20px;margin:0 auto 10px}
.tariffe-zone-card h4{font-size:14px;font-weight:700;margin-bottom:4px}
.tariffe-zone-desc{font-size:11px;color:var(--n5);line-height:1.4;margin-bottom:8px}
.tariffe-zone-price{font-size:13px;color:var(--g);font-weight:700}

.tariffe-countries{display:flex;flex-direction:column;gap:20px}
.tariffe-country-zone h3{font-size:16px;font-weight:700;display:flex;align-items:center;gap:8px;margin-bottom:10px}
.tariffe-country-zone-dot{width:10px;height:10px;border-radius:50%;display:inline-block;flex-shrink:0}
.tariffe-country-list{display:flex;flex-wrap:wrap;gap:6px}
.tariffe-country-tag{padding:6px 14px;background:var(--s0);border:1px solid var(--s2);border-radius:20px;font-size:12px;color:var(--n5);cursor:pointer;transition:all .15s;text-decoration:none}
.tariffe-country-tag:hover{background:var(--gl);border-color:var(--g);color:var(--gd)}

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

/* ═══ SERVIZI PAGE ═══ */
.servizi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;max-width:1100px;margin:0 auto}
.servizi-card{background:#fff;border:1px solid var(--s2);border-radius:14px;padding:28px 24px;transition:all .25s;display:flex;flex-direction:column}
.servizi-card:hover{border-color:var(--g);transform:translateY(-3px);box-shadow:0 8px 24px rgba(0,0,0,.06)}
.servizi-icon{font-size:36px;margin-bottom:14px}
.servizi-card h3{font-size:16px;font-weight:700;margin-bottom:8px}
.servizi-card p{font-size:13px;color:var(--n5);line-height:1.7;flex:1}
.servizi-link{display:inline-block;margin-top:12px;font-size:13px;font-weight:600;color:var(--g);cursor:pointer;text-decoration:none;transition:color .15s}
.servizi-link:hover{color:var(--gd)}

.servizi-split{display:grid;grid-template-columns:1.2fr 1fr;gap:48px;max-width:1100px;margin:0 auto;align-items:center}
.servizi-badge{display:inline-block;background:var(--gl);color:var(--gd);padding:5px 14px;border-radius:20px;font-size:12px;font-weight:700;margin-bottom:14px}
.servizi-split-content h2{font-size:clamp(22px,3vw,28px);font-weight:800;margin-bottom:12px}
.servizi-split-content p{font-size:14px;color:var(--n5);line-height:1.8;margin-bottom:8px}
.servizi-checklist{display:flex;flex-direction:column;gap:6px;margin-top:12px}
.servizi-check-item{font-size:13px;color:var(--n5);padding:4px 0;padding-left:4px}

.servizi-mock{background:#fff;border:1px solid var(--s2);border-radius:14px;overflow:hidden;box-shadow:0 8px 30px rgba(0,0,0,.06)}
.servizi-mock-header{background:var(--n);padding:10px 16px;display:flex;align-items:center}
.servizi-mock-dots{display:flex;gap:6px}
.servizi-mock-dots span{width:10px;height:10px;border-radius:50%;background:rgba(255,255,255,.15)}
.servizi-mock-dots span:first-child{background:#EF4444}
.servizi-mock-dots span:nth-child(2){background:#F59E0B}
.servizi-mock-dots span:last-child{background:#10B981}
.servizi-mock-body{padding:20px;display:flex;flex-direction:column;gap:12px}
.servizi-mock-stat{border-radius:10px;padding:16px;text-align:center}
.servizi-mock-bar{height:10px;background:var(--s1);border-radius:6px;overflow:hidden}
.servizi-mock-bar-fill{height:100%;background:var(--g);border-radius:6px}

.servizi-carriers-list{display:flex;flex-direction:column;gap:12px;margin-top:16px}
.servizi-carrier-row{display:flex;align-items:center;gap:16px;padding:10px 0;border-bottom:1px solid var(--s2)}
.servizi-carrier-row:last-child{border:none}
.servizi-carrier-name{font-size:18px;font-weight:900;font-style:italic;width:60px;flex-shrink:0}
.servizi-carrier-desc{font-size:13px;color:var(--n5);line-height:1.5}

@media(max-width:768px){
  .servizi-grid{grid-template-columns:1fr}
  .servizi-split{grid-template-columns:1fr;direction:ltr!important}
  .servizi-split-visual{order:-1}
  .servizi-split-content{direction:ltr!important}
  .courier-logos{flex-direction:row!important}
}

/* ═══ AI CHAT WIDGET ═══ */
.ai-fab{position:fixed;bottom:20px;right:20px;z-index:9990;display:inline-flex;align-items:center;gap:10px;padding:12px 18px;background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none;border-radius:999px;cursor:pointer;font-size:14px;font-weight:700;box-shadow:0 8px 24px rgba(16,185,129,.35);transition:all .25s ease;font-family:inherit}
.ai-fab:hover{transform:translateY(-2px);box-shadow:0 12px 32px rgba(16,185,129,.45)}
.ai-fab-hidden{display:none}
.ai-fab-icon{font-size:20px;line-height:1}
.ai-fab-text{letter-spacing:.2px}
.ai-panel{position:fixed;bottom:20px;right:20px;z-index:9991;width:380px;height:560px;max-height:80vh;background:#fff;border-radius:16px;box-shadow:0 20px 60px rgba(15,23,42,.25);display:none;flex-direction:column;overflow:hidden;animation:aiSlideUp .3s ease}
.ai-panel-open{display:flex}
@keyframes aiSlideUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
.ai-header{padding:14px 16px;background:linear-gradient(135deg,#10b981,#059669);color:#fff;display:flex;justify-content:space-between;align-items:center;flex-shrink:0}
.ai-title{font-size:14px;font-weight:700}
.ai-sub{font-size:11px;color:rgba(255,255,255,.85);margin-top:2px}
.ai-icon-btn{background:rgba(255,255,255,.15);border:none;color:#fff;width:30px;height:30px;border-radius:50%;cursor:pointer;font-size:14px;display:inline-flex;align-items:center;justify-content:center;transition:background .15s;font-family:inherit}
.ai-icon-btn:hover{background:rgba(255,255,255,.3)}
.ai-messages{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:10px;background:#f8fafc;font-size:14px;line-height:1.55}
.ai-greeting{text-align:center;padding:8px 4px;color:#1a1a2e}
.ai-greeting h4{font-size:15px;font-weight:700;margin-bottom:6px}
.ai-greeting p{font-size:13px;color:#475569;margin-bottom:14px}
.ai-suggestions{display:flex;flex-direction:column;gap:6px}
.ai-suggest{background:#fff;border:1px solid #e2e8f0;border-radius:10px;padding:10px 12px;font-size:13px;color:#1a1a2e;text-align:left;cursor:pointer;transition:all .15s;font-family:inherit}
.ai-suggest:hover{border-color:#10b981;background:#f0fdf4}
.ai-msg{padding:10px 14px;border-radius:14px;max-width:85%;word-wrap:break-word;animation:aiFadeIn .2s ease}
@keyframes aiFadeIn{from{opacity:0;transform:translateY(4px)}to{opacity:1}}
.ai-msg-user{background:#10b981;color:#fff;align-self:flex-end;border-bottom-right-radius:4px}
.ai-msg-assistant{background:#fff;color:#1a1a2e;align-self:flex-start;border:1px solid #e2e8f0;border-bottom-left-radius:4px}
.ai-msg-assistant code{background:#f1f5f9;padding:2px 6px;border-radius:4px;font-size:12px;font-family:'Courier New',monospace}
.ai-typing{display:inline-flex;gap:4px;align-items:center;padding:14px 16px}
.ai-typing span{width:7px;height:7px;background:#94a3b8;border-radius:50%;animation:aiBlink 1.2s infinite ease-in-out}
.ai-typing span:nth-child(2){animation-delay:.2s}
.ai-typing span:nth-child(3){animation-delay:.4s}
@keyframes aiBlink{0%,80%,100%{opacity:.3;transform:scale(.8)}40%{opacity:1;transform:scale(1)}}
.ai-form{display:flex;gap:8px;padding:12px;background:#fff;border-top:1px solid #e2e8f0;flex-shrink:0;align-items:flex-end}
#ai-input{flex:1;padding:10px 12px;border:1.5px solid #e2e8f0;border-radius:10px;font-size:14px;font-family:inherit;color:#1a1a2e;background:#f8fafc;resize:none;outline:none;transition:border-color .15s;line-height:1.4;max-height:120px}
#ai-input:focus{border-color:#10b981;background:#fff}
#ai-send{background:#10b981;color:#fff;border:none;width:40px;height:40px;border-radius:50%;cursor:pointer;font-size:14px;font-weight:700;flex-shrink:0;transition:background .15s}
#ai-send:hover{background:#059669}
@media(max-width:560px){
  .ai-fab{bottom:14px;right:14px;padding:10px 14px;font-size:13px}
  .ai-fab-text{display:none}
  .ai-panel{bottom:0;right:0;left:0;width:100%;height:100vh;height:100dvh;max-height:100vh;max-height:100dvh;border-radius:0}
  .ai-header{padding-top:calc(14px + env(safe-area-inset-top))}
  .ai-form{padding-bottom:calc(12px + env(safe-area-inset-bottom))}
}
[data-theme="dark"] .ai-panel{background:#0F172A}
[data-theme="dark"] .ai-messages{background:#0B1120}
[data-theme="dark"] .ai-msg-assistant{background:#1E293B;color:#E2E8F0;border-color:#334155}
[data-theme="dark"] .ai-msg-assistant code{background:#0F172A;color:#10b981}
[data-theme="dark"] .ai-suggest{background:#1E293B;color:#E2E8F0;border-color:#334155}
[data-theme="dark"] .ai-suggest:hover{background:rgba(16,185,129,.1);border-color:#10b981}
[data-theme="dark"] .ai-greeting{color:#E2E8F0}
[data-theme="dark"] .ai-greeting p{color:#94A3B8}
[data-theme="dark"] .ai-form{background:#1E293B;border-top-color:#334155}
[data-theme="dark"] #ai-input{background:#0F172A;color:#E2E8F0;border-color:#334155}

/* ═══ PAGINA CONTATTI ═══ */
.contatti-page{overflow-x:hidden}
.contatti-page .fade-in{max-width:800px;margin:0 auto;width:100%}
.contatti-textarea{width:100%;padding:10px 12px;border:1.5px solid var(--s2);border-radius:8px;font-size:13px;font-family:inherit;resize:vertical;background:#fff;color:var(--n);box-sizing:border-box;outline:none;transition:border-color .2s}
.contatti-textarea:focus{border-color:var(--g);box-shadow:0 0 0 3px rgba(16,185,129,.1)}
@media(max-width:768px){
  .contatti-page .card{padding:18px 16px}
  .contatti-page .card[style*="padding:28px"]{padding:20px 16px!important}
  .contatti-cards{gap:12px!important}
  .contatti-page .page-hdr{padding:0 4px}
}
@media(max-width:480px){
  .contatti-page .card[style*="padding:28px"]{padding:16px 14px!important}
  .contatti-page h2{font-size:16px!important}
}
[data-theme="dark"] .contatti-textarea{background:#1E293B;border-color:#334155;color:#E2E8F0}
[data-theme="dark"] .contatti-textarea:focus{border-color:var(--g)}

/* ═══ COOKIE BANNER ═══ */
.cookie-banner{position:fixed;bottom:0;left:0;right:0;z-index:10000;background:var(--n);border-top:1px solid rgba(255,255,255,.1);padding:20px;box-shadow:0 -4px 24px rgba(0,0,0,.3);animation:cookieSlideUp .4s ease}
@keyframes cookieSlideUp{from{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}
.cookie-banner-hide{animation:cookieSlideDown .4s ease forwards}
@keyframes cookieSlideDown{from{transform:translateY(0);opacity:1}to{transform:translateY(100%);opacity:0}}
.cookie-banner-inner{max-width:1200px;margin:0 auto;display:flex;align-items:center;gap:20px;flex-wrap:wrap}
.cookie-banner-content{display:flex;gap:14px;align-items:flex-start;flex:1;min-width:300px}
.cookie-banner-icon{font-size:32px;flex-shrink:0;margin-top:2px}
.cookie-banner-text h3{font-size:15px;font-weight:700;color:#fff;margin-bottom:4px}
.cookie-banner-text p{font-size:12px;color:#fff;line-height:1.6}
.cookie-banner-link{font-size:11px;color:#6ee7b7;cursor:pointer;text-decoration:underline;display:inline-block;margin-top:4px}
.cookie-banner-link:hover{text-decoration:underline}
.cookie-banner-actions{display:flex;gap:8px;flex-shrink:0;flex-wrap:wrap}
/* Bottoni del cookie banner: testo bianco (sfondo scuro) */
.cookie-banner .btn{color:#fff}
.cookie-banner .btn-outline{background:transparent;border-color:rgba(255,255,255,.35);color:#fff}
.cookie-banner .btn-outline:hover{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.6);color:#fff}
.cookie-banner .btn-primary{color:#fff}

/* Cookie panel toggle */
.ck-category{border:1px solid var(--s2);border-radius:10px;padding:16px;margin-bottom:10px}
.ck-cat-header{display:flex;align-items:center;justify-content:space-between;gap:16px}
.ck-cat-info{flex:1}
.ck-cat-info h4{font-size:14px;font-weight:700;margin-bottom:2px}
.ck-cat-info p{font-size:12px;color:var(--n5);line-height:1.5}

/* Toggle switch */
.ck-toggle{position:relative;display:inline-block;width:44px;height:24px;flex-shrink:0}
.ck-toggle input{opacity:0;width:0;height:0}
.ck-slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background:var(--s3);transition:.25s;border-radius:24px}
.ck-slider:before{content:'';position:absolute;height:18px;width:18px;left:3px;bottom:3px;background:#fff;transition:.25s;border-radius:50%}
.ck-toggle input:checked + .ck-slider{background:var(--g)}
.ck-toggle input:checked + .ck-slider:before{transform:translateX(20px)}
.ck-slider.ck-always{background:var(--g);opacity:.6;cursor:not-allowed}
.ck-slider.ck-always:before{transform:translateX(20px)}

/* Cookie policy table */
.ck-table{margin:12px 0;overflow-x:auto}
.ck-table table{width:100%;font-size:12px;border-collapse:collapse}
.ck-table th,.ck-table td{padding:8px 12px;text-align:left;border-bottom:1px solid var(--s2)}
.ck-table th{font-weight:700;font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:var(--n5);background:var(--s0)}

@media(max-width:768px){
  .cookie-banner-inner{flex-direction:column;align-items:stretch}
  .cookie-banner-actions{justify-content:stretch}
  .cookie-banner-actions .btn{flex:1;justify-content:center}
}

/* ═══ HAMBURGER BUTTON ═══ */
.sb-hamburger{display:none;position:fixed;top:12px;left:12px;z-index:10000;width:40px;height:40px;border-radius:8px;background:var(--n);color:#fff;border:none;font-size:20px;cursor:pointer;align-items:center;justify-content:center;box-shadow:0 2px 10px rgba(0,0,0,.15)}
.sb-hamburger:hover{background:var(--n7)}

/* ═══ DARK MODE ═══ */
[data-theme="dark"]{--g:#34D399;--gd:#10B981;--gl:rgba(16,185,129,.15);--n:#E2E8F0;--n7:#CBD5E1;--n5:#94A3B8;--s4:#64748B;--s3:#475569;--s2:#334155;--s1:#1E293B;--s0:#0F172A;--o:#FB923C;--ol:rgba(249,115,22,.1);--r:#F87171;--rl:rgba(239,68,68,.1);--b:#60A5FA;--bl:rgba(59,130,246,.1)}
[data-theme="dark"] body{background:#0B1120;color:#E2E8F0}
[data-theme="dark"] .nav{background:#0B1120;border-bottom:1px solid #1E293B}
[data-theme="dark"] .hero{background:linear-gradient(135deg,#0B1120 0%,#1a2744 100%)}
[data-theme="dark"] .section-alt{background:#0F172A}
[data-theme="dark"] .section{background:#0B1120}
[data-theme="dark"] .card,[data-theme="dark"] .feature-card,[data-theme="dark"] .servizi-card{background:#1E293B;border-color:#334155}
[data-theme="dark"] .tbl-container{border-color:#334155}
[data-theme="dark"] table th{background:#0F172A;color:#94A3B8}
[data-theme="dark"] table td{border-color:#1E293B}
[data-theme="dark"] table tr:hover{background:rgba(255,255,255,.03)}
[data-theme="dark"] .field input,[data-theme="dark"] .field select,[data-theme="dark"] .field textarea{background:#0F172A;border-color:#334155;color:#E2E8F0}
[data-theme="dark"] .field input:focus,[data-theme="dark"] .field select:focus,[data-theme="dark"] .field textarea:focus{border-color:var(--g);background:#0B1120}
[data-theme="dark"] .modal{background:#1E293B;border-color:#334155}
[data-theme="dark"] .modal-hdr{border-color:#334155}
[data-theme="dark"] .settings-sidebar{background:#0F172A;border-color:#1E293B}
[data-theme="dark"] .ss-tab:hover{background:rgba(255,255,255,.05)}
[data-theme="dark"] .ss-tab.active{background:rgba(16,185,129,.1);color:var(--g)}
[data-theme="dark"] .settings-content{background:#0B1120}
[data-theme="dark"] .footer{background:#070D19}
[data-theme="dark"] .auth-bg{background:#0B1120}
[data-theme="dark"] .auth-card{background:#1E293B;border-color:#334155}
[data-theme="dark"] .cta{background:linear-gradient(135deg,#064E3B 0%,#065F46 100%)}
[data-theme="dark"] .mission{background:#0F172A;border-color:#1E293B}
[data-theme="dark"] .btn-outline{border-color:#334155;color:#E2E8F0}
[data-theme="dark"] .btn-outline:hover{border-color:#475569;background:#1E293B}
[data-theme="dark"] .btn-ghost:hover{background:#1E293B}
[data-theme="dark"] .stat-card{background:#1E293B;border-color:#334155}
[data-theme="dark"] .rate-card{background:#1E293B;border-color:#334155}
[data-theme="dark"] .rate-card.selected{border-color:var(--g);background:rgba(16,185,129,.08)}
[data-theme="dark"] .shipper-card{opacity:.9}
[data-theme="dark"] .guida-faq-item{border-color:#334155}
[data-theme="dark"] .guida-faq-q:hover{background:rgba(255,255,255,.03)}
[data-theme="dark"] .pay-summary{background:#0F172A}
[data-theme="dark"] .sidebar{background:#070D19}
[data-theme="dark"] .sb-item:hover{background:rgba(255,255,255,.06)}
[data-theme="dark"] .sb-item.active{background:rgba(16,185,129,.15)}
[data-theme="dark"] .legal-toc{background:#0F172A;border-color:#1E293B}
[data-theme="dark"] .cookie-banner{background:#0F172A;border-color:#1E293B}
[data-theme="dark"] .ck-category{border-color:#334155}
[data-theme="dark"] .servizi-mock{background:#1E293B;border-color:#334155}
[data-theme="dark"] .servizi-mock-body{background:#1E293B}
[data-theme="dark"] .calc-card{background:#1E293B;border-color:#334155}
[data-theme="dark"] .tariffe-carrier-card{background:#1E293B;border-color:#334155}
[data-theme="dark"] .test-card{background:#1E293B;border-color:#334155}

/* Dark mode toggle */
.theme-toggle{width:36px;height:36px;border-radius:8px;border:1.5px solid rgba(255,255,255,.15);background:transparent;color:#fff;cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;transition:all .2s}
.theme-toggle:hover{border-color:rgba(255,255,255,.3);background:rgba(255,255,255,.05)}

/* ═══ SEARCH / FILTER BAR ═══ */
.filter-bar{display:flex;gap:10px;margin-bottom:16px;flex-wrap:wrap;align-items:center}
.filter-bar .search-input{flex:1;min-width:200px;padding:9px 14px 9px 36px;border:1.5px solid var(--s2);border-radius:8px;font-size:13px;font-family:inherit;background:var(--s0) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='%2394A3B8' viewBox='0 0 16 16'%3E%3Cpath d='M11.742 10.344a6.5 6.5 0 1 0-1.397 1.398h-.001l3.85 3.85a1 1 0 0 0 1.415-1.414l-3.85-3.85zm-5.242.156a5 5 0 1 1 0-10 5 5 0 0 1 0 10z'/%3E%3C/svg%3E") no-repeat 12px center;transition:all .2s}
.filter-bar .search-input:focus{border-color:var(--g);background-color:#fff;outline:none}
[data-theme="dark"] .filter-bar .search-input{background-color:#0F172A;border-color:#334155;color:#E2E8F0}
[data-theme="dark"] .filter-bar .search-input:focus{background-color:#0B1120;border-color:var(--g)}
.filter-bar select{padding:9px 12px;border:1.5px solid var(--s2);border-radius:8px;font-size:12px;font-family:inherit;background:var(--s0);cursor:pointer}
[data-theme="dark"] .filter-bar select{background:#0F172A;border-color:#334155;color:#E2E8F0}

/* Pagination */
.pagination{display:flex;justify-content:center;align-items:center;gap:4px;margin-top:16px;font-size:13px}
.pagination button{min-width:34px;height:34px;border-radius:6px;border:1px solid var(--s2);background:transparent;cursor:pointer;font-size:12px;font-family:inherit;color:var(--n5);transition:all .15s}
.pagination button:hover{background:var(--s0);border-color:var(--s3)}
.pagination button.pg-active{background:var(--g);color:#fff;border-color:var(--g)}
.pagination button:disabled{opacity:.3;cursor:default}
.pagination .pg-info{font-size:12px;color:var(--s4);padding:0 8px}

/* ═══ SKELETON LOADER ═══ */
@keyframes shimmer{0%{background-position:-400px 0}100%{background-position:400px 0}}
.skeleton{background:linear-gradient(90deg,var(--s1) 25%,var(--s0) 50%,var(--s1) 75%);background-size:800px 100%;animation:shimmer 1.5s infinite;border-radius:6px}
[data-theme="dark"] .skeleton{background:linear-gradient(90deg,#1E293B 25%,#334155 50%,#1E293B 75%);background-size:800px 100%}
.skeleton-text{height:14px;margin-bottom:8px;width:80%}
.skeleton-text.short{width:40%}
.skeleton-text.medium{width:60%}
.skeleton-card{height:120px;margin-bottom:12px}
.skeleton-table-row{height:44px;margin-bottom:6px}
.skeleton-circle{width:40px;height:40px;border-radius:50%}
.skeleton-stat{height:80px;border-radius:12px}

.skeleton-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:24px}
.skeleton-rows{display:flex;flex-direction:column;gap:6px}

/* ═══ FILE UPLOAD DROP ZONE ═══ */
.dropzone{border:2px dashed var(--s3);border-radius:12px;padding:32px;text-align:center;cursor:pointer;transition:all .2s;background:var(--s0)}
.dropzone:hover,.dropzone.dragover{border-color:var(--g);background:var(--gl)}
.dropzone-icon{font-size:36px;margin-bottom:8px}
.dropzone-label{font-size:14px;font-weight:600;margin-bottom:4px}
.dropzone-hint{font-size:12px;color:var(--s4)}
.file-list{margin-top:12px}
.file-item{display:flex;align-items:center;gap:10px;padding:8px 12px;background:var(--s0);border-radius:8px;margin-bottom:6px;font-size:13px}
.file-item-name{flex:1;font-weight:500}
.file-item-size{color:var(--s4);font-size:11px}
.file-item-remove{color:var(--r);cursor:pointer;font-size:14px;padding:2px 6px}
[data-theme="dark"] .dropzone{background:#0F172A;border-color:#334155}
[data-theme="dark"] .dropzone:hover,[data-theme="dark"] .dropzone.dragover{border-color:var(--g);background:rgba(16,185,129,.05)}
[data-theme="dark"] .file-item{background:#1E293B}

/* ═══ MOBILE NAV MENU ═══ */
.nav-mobile-toggle{display:none;width:36px;height:36px;border:none;background:transparent;color:var(--n);font-size:22px;cursor:pointer;align-items:center;justify-content:center;border-radius:6px}
.nav-mobile-toggle:hover{background:var(--s1)}
.nav-mobile-menu{display:none;position:fixed;top:56px;left:0;right:0;background:var(--n);padding:16px;z-index:9000;border-top:1px solid rgba(255,255,255,.1);box-shadow:0 8px 30px rgba(0,0,0,.3);animation:fadeIn .2s ease}
.nav-mobile-menu.open{display:flex;flex-direction:column;gap:4px}
.nav-mobile-menu a{color:var(--s3);font-size:15px;font-weight:500;padding:12px 16px;border-radius:8px;transition:all .15s}
.nav-mobile-menu a:hover,.nav-mobile-menu a.nav-active{color:#fff!important;background:rgba(255,255,255,.06)}
.nav-mobile-menu .nvm-divider{height:1px;background:rgba(255,255,255,.08);margin:8px 0}

/* ═══ SEO SECTION ═══ */
.seo-section{padding:60px 20px;max-width:900px;margin:0 auto}
.seo-section h1{font-size:24px;font-weight:800;color:var(--n);margin-bottom:16px;line-height:1.3}
.seo-section h2{font-size:20px;font-weight:700;color:var(--n);margin:28px 0 12px;line-height:1.3}
.seo-section h3{font-size:18px;font-weight:700;color:var(--n);margin:24px 0 10px;line-height:1.3}
.seo-section p{font-size:15px;color:var(--n5);line-height:1.7;margin-bottom:12px}
[data-theme="dark"] .seo-section h1,[data-theme="dark"] .seo-section h2,[data-theme="dark"] .seo-section h3{color:var(--n)}
[data-theme="dark"] .seo-section p{color:var(--s4)}

/* ═══ SETTINGS MOBILE SELECT ═══ */
.settings-mobile-select{display:none;margin-bottom:16px}
.settings-mobile-select select{width:100%;padding:12px 14px;border:1.5px solid var(--s2);border-radius:10px;font-size:14px;font-weight:600;font-family:inherit;background:var(--s0);color:var(--n);cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%2394A3B8' viewBox='0 0 16 16'%3E%3Cpath d='M1.646 4.646a.5.5 0 0 1 .708 0L8 10.293l5.646-5.647a.5.5 0 0 1 .708.708l-6 6a.5.5 0 0 1-.708 0l-6-6a.5.5 0 0 1 0-.708z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:36px}
[data-theme="dark"] .settings-mobile-select select{background:#1E293B;border-color:#334155;color:#E2E8F0}

/* ═══ PLUGIN BANNER ═══ */
.plugin-banner{padding:48px 20px;text-align:center;background:linear-gradient(135deg,#0F172A 0%,#1E293B 100%);color:#fff;border-radius:0}
.plugin-banner h2{font-size:clamp(22px,3vw,32px);font-weight:800;margin-bottom:8px}
.plugin-banner p{color:var(--s3);font-size:15px;margin-bottom:24px;max-width:600px;margin-left:auto;margin-right:auto}
.plugin-cards{display:flex;gap:20px;justify-content:center;flex-wrap:wrap;max-width:700px;margin:0 auto}
.plugin-card{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:24px;flex:1;min-width:260px;text-align:left;transition:all .2s}
.plugin-card:hover{border-color:var(--g);background:rgba(16,185,129,.06)}
.plugin-card h3{font-size:16px;font-weight:700;margin-bottom:8px;display:flex;align-items:center;gap:8px}
.plugin-card p{font-size:13px;color:var(--s3);line-height:1.6;margin-bottom:12px}
.plugin-card ul{list-style:none;padding:0;margin:0 0 14px;font-size:12px;color:var(--s4)}
.plugin-card ul li{padding:3px 0}
.plugin-card ul li::before{content:'✓ ';color:var(--g)}

/* ═══ FAQ SCHEMA PAGE ═══ */
.faq-page{max-width:800px;margin:0 auto}
.faq-page .faq-item{border:1px solid var(--s2);border-radius:10px;margin-bottom:8px;overflow:hidden;transition:all .2s}
.faq-page .faq-item.open{border-color:var(--g)}
.faq-page .faq-q{padding:16px 20px;cursor:pointer;font-weight:600;font-size:14px;display:flex;justify-content:space-between;align-items:center;transition:all .15s}
.faq-page .faq-q:hover{background:var(--s0)}
.faq-page .faq-item.open .faq-q{color:var(--g);background:var(--gl)}
.faq-page .faq-a{padding:0 20px;max-height:0;overflow:hidden;transition:max-height .3s ease,padding .3s ease}
.faq-page .faq-item.open .faq-a{max-height:500px;padding:16px 20px}
.faq-page .faq-a p{font-size:14px;line-height:1.7;color:var(--n5);margin:0}
[data-theme="dark"] .faq-page .faq-item{border-color:#334155}
[data-theme="dark"] .faq-page .faq-q:hover{background:rgba(255,255,255,.03)}

/* ═══ AI AGENT BUTTON (below SEO section) ═══ */
.ai-agent-section{padding:28px 20px 56px;text-align:center;background:transparent}
.ai-agent-btn{display:inline-flex;align-items:center;gap:10px;padding:12px 22px;background:rgba(15,23,42,.04);border:1.5px dashed var(--s3);border-radius:999px;color:var(--n);font-size:14px;font-weight:600;cursor:pointer;transition:all .25s ease;text-decoration:none}
.ai-agent-btn:hover{background:var(--n);color:#fff;border-color:var(--n);border-style:solid;transform:translateY(-2px);box-shadow:0 8px 24px rgba(15,23,42,.18)}
.aia-icon{font-size:18px;line-height:1}
.aia-text{letter-spacing:.1px}
.aia-arrow{font-weight:800;transition:transform .25s ease}
.ai-agent-btn:hover .aia-arrow{transform:translateX(4px)}
@media(max-width:560px){
  .ai-agent-section{padding:20px 16px 40px}
  .ai-agent-btn{font-size:13px;padding:10px 16px;gap:8px;max-width:100%}
  .aia-text{white-space:normal;text-align:left}
}
[data-theme="dark"] .ai-agent-btn{background:rgba(255,255,255,.04);border-color:#334155;color:#E2E8F0}
[data-theme="dark"] .ai-agent-btn:hover{background:var(--g);border-color:var(--g);color:#fff}

/* ═══ RUBRICA INDIRIZZI (wizard step 1) — desktop ═══ */
/* Bottone "📖 Scegli dalla rubrica" prominente anche su desktop */
.rubrica-pick{background:var(--gl);border-color:#A7F3D0;color:var(--gd);font-weight:600}
.rubrica-pick:hover{background:#A7F3D0;border-color:var(--g)}
.rubrica-save{color:var(--n5)}

/* ═══ WIZARD BUTTONS (Crea Spedizione) — full-width, 50/50 when paired ═══ */
.wizard-container .btn{width:100%;justify-content:center;min-height:44px}
/* When 2+ buttons share a horizontal flex row, split equally (50/50 for back+next) */
.wizard-container div[style*="display:flex"]:not([style*="flex-direction:column"]) > .btn{flex:1;width:auto;min-width:0}
/* Header inline action buttons (rubrica, etc.) stay compact */
.wizard-container .card > div[style*="display:flex"][style*="justify-content:space-between"] > div[style*="display:flex"] > .btn-sm{min-height:36px}

/* ═══ WIZARD MOBILE (Crea Spedizione) ═══ */
/* Edge-to-edge form on mobile, no padding around it, fields fully readable */
@media(max-width:768px){
  /* Kill padding around the wizard form */
  .frontend-content:has(.wizard-container){padding:64px 0 24px}
  .wizard-container{max-width:100%;margin:0;padding:0}

  /* Page header stays padded for readability */
  .wizard-container .page-hdr{padding:0 14px;margin-bottom:14px}

  /* Stepper remains centered with minimal padding */
  .wizard-container .wizard-steps{padding:0 10px;margin-bottom:18px}

  /* Cards edge-to-edge, no lateral border, minimal padding */
  .wizard-container .card{padding:16px 14px;border-radius:0;border-left:none;border-right:none;margin-left:0;margin-right:0}
  .wizard-container .card + .card{margin-top:8px}

  /* Tighter form grids with larger gaps for tap targets */
  .wizard-container .form-grid{grid-template-columns:1fr;gap:12px}
  .wizard-container .form-grid-3{grid-template-columns:1fr;gap:12px}
  .wizard-container .field label{font-size:12px;font-weight:600;letter-spacing:.3px}
  .wizard-container .field input,
  .wizard-container .field select,
  .wizard-container .field textarea{padding:12px 14px;font-size:16px;border-radius:10px;min-height:46px;width:100%}

  /* Force span cells back to full width on single-column grids */
  .wizard-container .form-grid .field[style*="grid-column:span 2"]{grid-column:auto!important}

  /* Address layout + rubrica: stack vertically, rubrica NOT sticky */
  .wizard-container .wz-addr-layout{grid-template-columns:1fr!important;gap:10px!important;display:flex!important;flex-direction:column}
  .wizard-container .rubrica-card{position:static!important;top:auto!important}
  /* Se la rubrica HA indirizzi → la mostro SOPRA il form (order:-1) */
  .wizard-container .rubrica-col.has-addrs{order:-1;margin-bottom:4px}
  /* Se vuota, resta sotto il form (utente deve prima compilare e salvare) */
  .wizard-container .rubrica-col.empty{order:1}

  /* Card header (title + buttons rubrica) wraps cleanly */
  .wizard-container .card > div[style*="justify-content:space-between"]{flex-wrap:wrap;gap:8px;align-items:flex-start}
  .wizard-container .rubrica-actions{width:100%!important;display:flex!important;gap:8px!important;flex-direction:row;margin-top:4px}
  .wizard-container .rubrica-actions .btn{flex:1;justify-content:center;min-width:0;min-height:42px;font-size:13px;font-weight:600}
  /* Stile prominente bottone "📖 Scegli dalla rubrica" */
  .wizard-container .rubrica-pick{background:var(--gl)!important;border-color:#A7F3D0!important;color:var(--gd)!important}
  .wizard-container .rubrica-pick:hover{background:#A7F3D0!important;border-color:var(--g)!important}
  /* "Salva" piu' discreto */
  .wizard-container .rubrica-save{background:#fff!important;color:var(--n5)!important}

  /* Package inputs: peso/L/W/H/Qty — 2 columns, peso pieno */
  .wizard-container .pkg-fields-grid{grid-template-columns:1fr 1fr!important;gap:10px!important}
  .wizard-container .pkg-fields-grid .field:first-child{grid-column:span 2}

  /* Package action buttons full width */
  .wizard-container .pkg-row ~ div[style*="display:flex;gap:8px"]{flex-direction:column;gap:8px}
  .wizard-container .pkg-row ~ div[style*="display:flex;gap:8px"] .btn{width:100%;justify-content:center}

  /* Date/time picker: breathable cells */
  .wizard-container .date-grid{grid-template-columns:repeat(4,1fr);gap:6px}
  .wizard-container .date-cell{padding:10px 4px;font-size:12px}
  .wizard-container .time-grid{grid-template-columns:repeat(3,1fr);gap:6px}
  .wizard-container .time-cell{padding:12px 4px;font-size:14px}

  /* Pickup options: stack */
  .wizard-container .pickup-grid{grid-template-columns:1fr;gap:10px}
  .wizard-container .pickup-opt{padding:14px;display:flex;align-items:center;gap:14px;text-align:left}
  .wizard-container .pickup-opt .po-icon{font-size:28px;margin-bottom:0;flex-shrink:0}
  .wizard-container .pickup-opt h4{font-size:14px;margin-bottom:2px}
  .wizard-container .pickup-opt p{font-size:12px}

  /* Wizard navigation buttons: bottom-bar look con padding laterale per breathing room */
  .wizard-container div[style*="display:flex"][style*="gap:12px"][style*="justify-content"]{padding:14px 16px;background:var(--s0);margin-top:12px;gap:10px;border-radius:0}
  .wizard-container div[style*="display:flex"][style*="gap:12px"][style*="justify-content"] .btn{min-height:48px}
  /* Step 1 (solo "Continua" annidato in wz-addr-layout): garantisco il padding laterale */
  .wizard-container .wz-addr-layout div[style*="justify-content:flex-end"]{padding:14px 16px;background:var(--s0);margin-top:12px}

  /* Rate cards compact */
  .wizard-container .rate-card{padding:14px;gap:10px}
  .wizard-container .carrier-info{padding:12px;font-size:12px;gap:8px}
  .wizard-container .carrier-info-item{min-width:calc(50% - 4px);flex:0 0 calc(50% - 4px);text-align:left}

  /* Payment layout: summary on top, stacked */
  .wizard-container .pay-layout{display:flex;flex-direction:column;gap:12px}
  .wizard-container .pay-summary{order:-1;position:static;padding:18px;margin:0 14px;border-radius:12px}

  /* Auth gate card bodies breathe */
  .wizard-container .agc-header{padding:14px 16px}
  .wizard-container .agc-header h4{font-size:14px}
  .wizard-container .agc-header p{font-size:12px}
  .wizard-container .auth-gate-card .agc-body{padding:0 16px 16px}

  /* Package weight summary chips wrap */
  .wizard-container .pkg-weight-calc{flex-direction:column;align-items:flex-start!important;gap:6px!important;padding:10px 12px!important}
  .wizard-container .pkg-weight-calc span{font-size:12px}
}

@media(max-width:480px){
  .wizard-container .card{padding:14px 12px}
  .wizard-container .page-hdr{padding:0 12px}
  .wizard-container .page-hdr h1{font-size:18px}
  .wizard-container .page-hdr p{font-size:12px}
  .wizard-container .date-grid{grid-template-columns:repeat(3,1fr)}
  .wizard-container .time-grid{grid-template-columns:repeat(2,1fr)}
  .wizard-container .pay-summary{margin:0 12px}
}

/* Fallback for browsers without :has() — reduce frontend-content padding on mobile anyway */
@supports not selector(:has(*)){
  @media(max-width:768px){
    .frontend-content{padding-left:0;padding-right:0}
  }
}
