/* Autismus-Stiftung Theme v2.0 — derived from nav-hero-footer-v2 mockup */
html,body{margin:0;padding:0;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",system-ui,sans-serif;color:var(--text);background:#ffffff;-webkit-font-smoothing:antialiased}
*{box-sizing:border-box}
:root{--brand:#d92d68;
    --brand-dark:#b01f52;
    --brand-soft:#fdeef4;
    --brand-softer:#fef6f9;
    --ink:#231f20;
    --text:#231f20;
    --text-muted:#6b7280;
    --border:#e5e7eb;
    --bg:#f9fafb;
    --white:#ffffff;
    --footer-bg:#f3f4f6;
    --shadow-sm:0 1px 2px rgba(0,0,0,.05);
    --shadow-md:0 4px 12px rgba(0,0,0,.08);
    --shadow-lg:0 16px 48px rgba(217,45,104,.15);}
*{box-sizing:border-box}
html, body{margin:0;padding:0;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",system-ui,sans-serif;color:var(--text);background:#eef1f5;-webkit-font-smoothing:antialiased}
.viewports{display:flex;flex-direction:column;gap:56px;padding:48px 24px;max-width:1480px;margin:0 auto}
.viewport-label::before{content:"";display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--brand)}
.brand-bar{height:4px;background:var(--brand)}
.logo{display:flex;align-items:center;text-decoration:none;flex-shrink:0}
.logo svg.as-logo{height:44px;width:auto;display:block}
.footer-brand svg.as-logo{height:56px;width:auto;display:block;margin-bottom:20px}
.m-drawer-head svg.as-logo{height:38px;width:auto}
.nav-wrap{background:var(--white)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;padding:18px 32px;gap:20px}
.nav-actions{display:flex;align-items:center;gap:6px;flex-shrink:0}
.icon-btn{width:40px;height:40px;border-radius:50%;border:none;background:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--ink);transition:all .2s}
.icon-btn:hover{background:var(--brand-soft);color:var(--brand)}
.icon-btn svg{width:20px;height:20px}
.btn-donate{display:inline-flex;align-items:center;gap:6px;padding:12px 26px;background:var(--brand);color:#fff;border-radius:999px;text-decoration:none;font-weight:700;font-size:14px;letter-spacing:.02em;box-shadow:0 4px 14px rgba(217,45,104,.35);transition:all .2s;white-space:nowrap;text-transform:uppercase;margin-left:8px;border:none;cursor:pointer}
.btn-donate:hover{background:var(--brand-dark);transform:translateY(-1px)}
.d-menu{display:flex;align-items:center;gap:2px;list-style:none;margin:0;padding:0;flex:1;justify-content:center}
.d-menu>li{position:relative}
.d-menu>li>a{display:flex;align-items:center;gap:6px;padding:14px 20px;color:var(--ink);text-decoration:none;font-weight:600;font-size:15px;border-radius:8px;transition:all .15s;white-space:nowrap;letter-spacing:.01em;position:relative}
.d-menu>li>a:hover, .d-menu>li.open>a{color:var(--brand)}
.d-menu>li>a .chev{width:14px;height:14px;transition:transform .2s}
.d-menu>li.open>a .chev{transform:rotate(180deg)}
.d-menu>li.open>a::after{content:"";position:absolute;left:20px;right:20px;bottom:6px;height:2px;background:var(--brand);border-radius:2px}
.megamenu{position:absolute;top:calc(100% + 10px);left:50%;transform:translateX(-50%);width:860px;background:var(--white);border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow-lg);display:none;z-index:100;overflow:hidden}
.d-menu>li.open>.megamenu{display:flex}
.megamenu::before{content:"";position:absolute;top:-7px;left:50%;transform:translateX(-50%) rotate(45deg);width:14px;height:14px;background:var(--white);border-left:1px solid var(--border);border-top:1px solid var(--border)}
.mega-left{flex:1.35;padding:24px 22px;border-right:1px solid var(--border);background:var(--white)}
.mega-right{flex:1;padding:24px 22px;background:var(--brand-softer)}
.mega-title{font-size:11px;font-weight:700;color:var(--brand);text-transform:uppercase;letter-spacing:.1em;margin:0 0 14px}
.mega-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:4px}
.mega-list li a{display:flex;align-items:center;gap:12px;padding:12px;border-radius:10px;text-decoration:none;color:var(--text);transition:all .15s;border:1px solid transparent;cursor:pointer}
.mega-list li a:hover, .mega-list li.active a{background:var(--brand-softer);border-color:var(--brand-soft)}
.mega-list li.active a{background:var(--brand-soft)}
.mega-icon{flex-shrink:0;width:38px;height:38px;border-radius:9px;background:var(--brand-soft);color:var(--brand);display:flex;align-items:center;justify-content:center;transition:all .15s}
.mega-icon svg{width:19px;height:19px}
.mega-list li.active .mega-icon, .mega-list li a:hover .mega-icon{background:var(--brand);color:#fff}
.mega-text{flex:1;min-width:0}
.mega-text h4{margin:0 0 2px;font-size:14px;font-weight:700;color:var(--ink)}
.mega-text p{margin:0;font-size:12px;color:var(--text-muted);line-height:1.4;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mega-arrow{color:var(--text-muted);flex-shrink:0}
.mega-list li.active .mega-arrow, .mega-list li a:hover .mega-arrow{color:var(--brand)}
.mega-right-title{font-size:11px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em;margin:0 0 14px}
.mega-right h3{font-size:16px;font-weight:700;color:var(--ink);margin:0 0 14px}
.l3-list{list-style:none;margin:0;padding:0}
.l3-list li a{display:flex;align-items:center;justify-content:space-between;padding:9px 10px;border-radius:6px;text-decoration:none;color:var(--ink);font-size:13.5px;font-weight:500;transition:all .15s}
.l3-list li a:hover{background:var(--white);color:var(--brand);padding-left:14px}
.l3-list li a::before{content:"›";color:var(--brand);font-weight:700;margin-right:8px}
.l3-panels{position:relative;min-height:180px}
.l3-panel{display:none}
.l3-panel.active{display:block}
.l3-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:30px 16px;color:var(--text-muted);font-size:13px;line-height:1.5;border:1px dashed var(--brand-soft);border-radius:10px;background:var(--white);min-height:160px}
.l3-empty svg{width:32px;height:32px;color:var(--brand);opacity:.5;margin-bottom:10px}
.l3-empty strong{color:var(--ink);font-size:14px;font-weight:700;display:block;margin-bottom:4px}
.l3-panels.has-active .l3-empty{display:none}
.mega-cta{margin-top:16px;padding-top:14px;border-top:1px solid var(--brand-soft);font-size:12px}
.mega-cta a{color:var(--brand);text-decoration:none;font-weight:700}
.t-top{display:flex;align-items:center;justify-content:space-between;padding:16px 24px}
.t-menu-row{border-top:1px solid var(--border);border-bottom:1px solid var(--border);background:var(--white);position:relative}
.t-menu{display:flex;list-style:none;margin:0;padding:0;justify-content:center;gap:4px}
.t-menu>li{position:relative}
.t-menu>li>button{display:flex;align-items:center;gap:6px;padding:14px 18px;color:var(--ink);background:none;border:none;font-weight:600;font-size:14px;white-space:nowrap;border-bottom:3px solid transparent;cursor:pointer;font-family:inherit}
.t-menu>li>button:hover, .t-menu>li.open>button{color:var(--brand);border-bottom-color:var(--brand)}
.t-menu .chev{width:13px;height:13px;transition:transform .2s}
.t-menu>li.open .chev{transform:rotate(180deg)}
.t-dropdown{position:absolute;top:100%;left:0;right:0;background:var(--white);border-bottom:1px solid var(--border);box-shadow:0 8px 20px rgba(0,0,0,.06);display:none;z-index:50;padding:24px}
.t-menu>li.open + .t-dropdown-wrap .t-dropdown, .t-menu-row.open .t-dropdown.active{display:flex}
.t-dropdown{display:none;gap:24px}
.t-dropdown.active{display:flex}
.t-dropdown-left{flex:1}
.t-dropdown-right{flex:1;padding-left:24px;border-left:1px solid var(--border)}
.t-dropdown h4{font-size:11px;font-weight:700;color:var(--brand);text-transform:uppercase;letter-spacing:.08em;margin:0 0 12px}
.t-dropdown ul{list-style:none;margin:0;padding:0}
.t-dropdown li a{display:block;padding:8px 10px;color:var(--ink);text-decoration:none;font-size:13.5px;font-weight:500;border-radius:6px}
.t-dropdown li a:hover, .t-dropdown li.active a{background:var(--brand-soft);color:var(--brand)}
.t-dropdown li a::before{content:"›";color:var(--brand);font-weight:700;margin-right:8px}
.tL3{display:none;list-style:none;margin:0;padding:0}
.tL3.active{display:block}
.t-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:20px 12px;color:var(--text-muted);font-size:12.5px;line-height:1.5;border:1px dashed var(--brand-soft);border-radius:8px;background:var(--brand-softer);min-height:120px}
.t-empty strong{color:var(--ink);font-size:13px;font-weight:700;display:block;margin-bottom:2px}
.t-dropdown-right.has-active .t-empty{display:none}
.m-hamburger{display:flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:10px;background:transparent;border:none;cursor:pointer;color:var(--ink)}
.m-hamburger:hover{background:var(--brand-soft);color:var(--brand)}
.m-hamburger svg{width:26px;height:26px}
.m-drawer{position:absolute;top:0;left:0;width:88%;max-width:340px;height:100%;background:var(--white);box-shadow:4px 0 24px rgba(0,0,0,.15);padding:20px;z-index:50;display:none;flex-direction:column}
.m-drawer.open{display:flex}
.m-drawer-head{display:flex;align-items:center;justify-content:space-between;padding-bottom:16px;border-bottom:1px solid var(--border);margin-bottom:16px}
.m-drawer-close{width:38px;height:38px;border-radius:50%;border:none;background:#f3f4f6;cursor:pointer;font-size:22px;display:flex;align-items:center;justify-content:center;color:var(--ink)}
.m-list{list-style:none;margin:0;padding:0;flex:1;overflow-y:auto}
.m-list>li{border-bottom:1px solid var(--border)}
.m-item{display:flex;align-items:center;justify-content:space-between;padding:16px 4px;color:var(--ink);text-decoration:none;font-weight:700;font-size:16px;cursor:pointer;background:none;border:none;width:100%;text-align:left;font-family:inherit}
.m-item .chev{width:20px;height:20px;transition:transform .2s;color:var(--text-muted)}
.m-item.open{color:var(--brand)}
.m-item.open .chev{transform:rotate(180deg);color:var(--brand)}
.m-sub{list-style:none;margin:0;padding:0 0 14px 4px;display:none}
.m-item.open + .m-sub{display:block}
.m-sub>li{margin-bottom:2px}
.m-sub .m-l2{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;color:var(--ink);text-decoration:none;font-size:14.5px;font-weight:600;border-radius:6px;background:none;border:none;width:100%;text-align:left;font-family:inherit;cursor:pointer}
.m-sub .m-l2:hover{background:var(--brand-softer);color:var(--brand)}
.m-sub .m-l2 .chev{width:16px;height:16px;transition:transform .2s;color:var(--text-muted)}
.m-sub .m-l2.open{color:var(--brand)}
.m-sub .m-l2.open .chev{transform:rotate(180deg);color:var(--brand)}
.m-l3{list-style:none;margin:0;padding:4px 0 8px 18px;display:none;border-left:2px solid var(--brand-soft)}
.m-l2.open + .m-l3{display:block}
.m-l3 li a{display:block;padding:8px 12px;color:var(--text-muted);text-decoration:none;font-size:13.5px;border-radius:4px}
.m-l3 li a:hover{background:var(--brand-soft);color:var(--brand)}
.m-drawer-footer{padding-top:16px;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:12px}
.m-quick{display:flex;gap:8px;justify-content:space-around}
.m-quick .icon-btn{background:var(--brand-soft);color:var(--brand)}
.m-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.45);z-index:40;display:none}
.m-backdrop.open{display:block}
.m-nav-inner{padding:14px 16px}
.m-nav-inner .btn-donate{padding:9px 16px;font-size:12px;margin-left:0}
.m-nav-inner .logo svg.as-logo{height:36px}
.dummy-body h2{margin:0 0 8px;color:var(--brand);font-size:20px;font-weight:700}
.dummy-body p{color:var(--text-muted);max-width:560px;line-height:1.6;font-size:14.5px}
.footer-top-line{height:3px;background:var(--brand)}
.site-footer{background:var(--white);padding:44px 40px 28px}
.footer-grid{display:grid;grid-template-columns:1.5fr 1.3fr 1fr;gap:48px;max-width:1200px;margin:0 auto}
.footer-tagline{font-weight:700;color:var(--ink);font-size:16px;margin:0 0 16px}
.footer-address{color:var(--text-muted);font-size:14px;line-height:1.6;margin:0 0 14px}
.footer-contact{color:var(--text-muted);font-size:14px;line-height:1.8;margin:0 0 20px}
.footer-contact a{color:var(--ink);text-decoration:none;font-weight:600;display:inline-flex;align-items:center;gap:8px}
.footer-contact a:hover{color:var(--brand)}
.footer-contact svg{width:15px;height:15px;color:var(--brand);flex-shrink:0}
.footer-trust{display:flex;align-items:center;gap:10px;padding:12px;background:var(--bg);border-radius:10px}
.footer-trust .ssl{width:44px;height:32px;border:1px solid var(--border);border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:9px;color:#0a8a3a;font-weight:700;background:linear-gradient(180deg,#fff 50%,#f9fafb 50%);flex-shrink:0}
.footer-trust-text{font-size:11.5px;color:var(--text-muted);line-height:1.5;flex:1}
.footer-trust-text strong{color:var(--ink);display:block;font-size:12px;margin-bottom:2px}
.footer-col h3{color:var(--brand);font-size:16px;font-weight:700;margin:0 0 18px}
.footer-col ul{list-style:none;margin:0;padding:0}
.footer-col li{margin-bottom:12px}
.footer-col a{color:var(--ink);text-decoration:none;font-size:14px;display:flex;align-items:center;gap:10px;line-height:1.3}
.footer-col a::before{content:"";width:14px;height:9px;flex-shrink:0;background:var(--brand);-webkit-mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 14'><path d='M10 3h4a4 4 0 010 8h-4M14 11h-4a4 4 0 010-8h4M7 7h10' fill='none' stroke='black' stroke-width='2'/></svg>") center/contain no-repeat;mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 14'><path d='M10 3h4a4 4 0 010 8h-4M14 11h-4a4 4 0 010-8h4M7 7h10' fill='none' stroke='black' stroke-width='2'/></svg>") center/contain no-repeat;display:inline-block}
.footer-col a:hover{color:var(--brand)}
.footer-col-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.footer-legal{max-width:1200px;margin:36px auto 0;padding-top:20px;border-top:1px solid var(--border);display:flex;gap:32px}
.footer-legal a{color:var(--brand);text-decoration:none;font-size:13px;font-weight:700}
.footer-bottom{background:var(--footer-bg);padding:18px 40px;display:flex;justify-content:space-between;align-items:center;font-size:12.5px;color:var(--text-muted)}
.footer-bottom .heart{color:var(--brand)}
.footer-trust-row{max-width:1200px;margin:32px auto 0;padding:22px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);display:grid;grid-template-columns:1.3fr 1fr;gap:28px;align-items:center}
.trust-block h4{font-size:11px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;margin:0 0 12px}
.trust-badges{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.badge-pill{display:inline-flex;align-items:center;gap:10px;padding:8px 14px;border:1px solid var(--border);border-radius:10px;background:var(--white);font-size:11px;color:var(--ink);line-height:1.25;transition:all .15s;text-decoration:none}
.badge-pill:hover{border-color:var(--brand);background:var(--brand-softer)}
.badge-pill strong{display:block;font-size:12px;color:var(--ink);font-weight:700}
.badge-pill span{color:var(--text-muted);font-size:10px}
.badge-dot{width:30px;height:30px;border-radius:50%;background:var(--brand-soft);color:var(--brand);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.badge-dot svg{width:17px;height:17px}
.pay-row{display:flex;gap:6px;flex-wrap:wrap;align-items:center}
.pay{height:28px;min-width:46px;padding:0 10px;border:1px solid var(--border);border-radius:6px;background:var(--white);display:inline-flex;align-items:center;justify-content:center;font-size:10.5px;font-weight:800;color:var(--ink);letter-spacing:.03em}
.pay.visa{color:#1a1f71}
.pay.mc{background:linear-gradient(90deg,#eb001b 50%,#f79e1b 50%);color:#fff;border-color:transparent}
.pay.pp{color:#003087}
.pay.kl{background:#ffb3c7;color:#0b051d;border-color:#ffb3c7}
.pay.sepa{color:#10298e}
.pay.ap{color:#000}
.pay.gp{color:#000}
.mail-link{cursor:pointer}
.badge{display:inline-block;padding:3px 10px;border-radius:999px;background:var(--brand-soft);color:var(--brand);font-size:11px;font-weight:700;margin-left:8px}
.hero-v1{position: relative;
    width: 100%;
    height: 520px;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    padding-bottom: 56px;}
.hero-v1 .hero-bg{position:absolute;inset:0;background:#0e1a50 url(../img/as-hero-bg.jpg) center 30%/cover no-repeat}
.hero-v1 .hero-overlay{position: absolute;
    inset: 0;
    background: linear-gradient(
      108deg,
      rgba(6,12,45,0.92)   0%,
      rgba(12,22,72,0.82)  28%,
      rgba(14,26,80,0.48)  55%,
      rgba(0,0,0,0.08)    100%
    );}
.hero-v1 .hero-overlay::after{content: "";
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 56px;
    background: linear-gradient(to bottom, rgba(0,0,0,0.35) 0%, transparent 100%);}
.hero-v1 .hero-puzzle{position: absolute;
    right: -60px; top: 50%;
    transform: translateY(-50%);
    width: 500px; height: 500px;
    opacity: 0.06; fill: #fff;
    pointer-events: none;}
.hero-v1 .hero-breadcrumb{position: absolute;
    top: 0; left: 0; right: 0;
    z-index: 3;
    padding: 14px 64px;
    display: flex;
    align-items: center;
    gap: 0;
    font-size: 12px;
    font-weight: 600;
    letter-spacing: 0.02em;}
.hero-v1 .hero-breadcrumb a{color: rgba(255,255,255,0.75);
    text-decoration: none;
    display: inline-flex; align-items: center; gap: 5px;
    transition: color .15s;}
.hero-v1 .hero-breadcrumb a:hover{color: #fff;}
.hero-v1 .hero-breadcrumb .bc-sep{margin: 0 8px;
    color: rgba(255,255,255,0.35);
    font-size: 9px;}
.hero-v1 .hero-breadcrumb .bc-cur{color: rgba(255,255,255,0.95);}
.hero-v1 .hero-content{position: relative;
    z-index: 2;
    padding: 0 64px;
    max-width: 660px;}
.hero-v1 .hero-badge{display: inline-flex; align-items: center; gap: 7px;
    background: rgba(255,255,255,0.10);
    border: 1px solid rgba(255,255,255,0.25);
    border-radius: 999px;
    padding: 5px 14px;
    font-size: 12px; font-weight: 700;
    color: rgba(255,255,255,0.9);
    letter-spacing: 0.05em;
    margin-bottom: 16px;
    backdrop-filter: blur(8px);
    text-transform: uppercase;}
.hero-v1 .hero-badge::before{content: ""; width: 6px; height: 6px;
    border-radius: 50%; background: var(--brand); flex-shrink: 0;}
.hero-v1 h1{margin: 0 0 16px;
    font-size: clamp(26px, 3.5vw, 46px);
    font-weight: 800;
    line-height: 1.1;
    color: #fff;
    text-shadow: 0 2px 24px rgba(0,0,0,0.3);
    letter-spacing: -0.02em;}
.hero-v1 .hero-sub{margin: 0 0 28px;
    font-size: clamp(14px, 1.5vw, 17px);
    color: rgba(255,255,255,0.85);
    line-height: 1.6;
    max-width: 460px;
    text-shadow: 0 1px 8px rgba(0,0,0,0.2);}
.hero-v1 .hero-cta{display: inline-flex; align-items: center; gap: 8px;
    padding: 14px 30px;
    background: var(--brand); color: #fff;
    border-radius: 999px;
    font-weight: 800; font-size: 14px;
    letter-spacing: 0.04em;
    text-decoration: none;
    box-shadow: 0 6px 24px rgba(217,45,104,0.45);
    transition: transform .2s, box-shadow .2s;
    text-transform: uppercase;}
.hero-v1 .hero-cta:hover{transform: translateY(-2px); box-shadow: 0 10px 32px rgba(217,45,104,0.55);}
.footer-top-line{height: 3px; background: var(--brand);}
.site-footer{background: #fff;
    padding: 52px 48px 0;}
.footer-inner{max-width: 1200px;
    margin: 0 auto;}
.footer-top{display: grid;
    grid-template-columns: 1.8fr 1fr 1fr 1.2fr;
    gap: 40px;
    padding-bottom: 40px;
    border-bottom: 1px solid var(--border);}
.f-brand .f-tagline{font-size: 13.5px; font-weight: 700; color: var(--ink);
    margin: 16px 0 6px;}
.f-brand .f-address{font-size: 13px; color: var(--text-muted);
    line-height: 1.7; margin: 0 0 14px;}
.f-brand .f-contact{font-size: 13px; line-height: 2;}
.f-brand .f-contact a{color: var(--ink); text-decoration: none; font-weight: 600;
    display: inline-flex; align-items: center; gap: 7px;}
.f-brand .f-contact a:hover{color: var(--brand);}
.f-brand .f-contact svg{width: 14px; height: 14px; color: var(--brand); flex-shrink: 0;}
.f-nav h4{font-size: 11px; font-weight: 700; color: var(--brand);
    text-transform: uppercase; letter-spacing: .1em;
    margin: 0 0 16px;}
.f-nav ul{list-style: none; margin: 0; padding: 0;}
.f-nav li{margin-bottom: 10px;}
.f-nav li a{font-size: 13.5px; color: var(--text); text-decoration: none;
    display: flex; align-items: center; gap: 8px;
    transition: color .15s;}
.f-nav li a::before{content: ""; width: 4px; height: 4px;
    border-radius: 50%; background: var(--brand); flex-shrink: 0;
    opacity: .5; transition: opacity .15s;}
.f-nav li a:hover{color: var(--brand);}
.f-nav li a:hover::before{opacity: 1;}
.f-trust h4{font-size: 11px; font-weight: 700; color: var(--text-muted);
    text-transform: uppercase; letter-spacing: .1em;
    margin: 0 0 16px;}
.f-trust-list{display: flex; flex-direction: column; gap: 10px;}
.f-trust-item{display: flex; align-items: center; gap: 10px;
    padding: 10px 12px;
    background: var(--brand-softer);
    border-radius: 8px;
    border-left: 3px solid var(--brand);}
.f-trust-icon{width: 32px; height: 32px; flex-shrink: 0;
    background: var(--brand-soft); border-radius: 6px;
    display: flex; align-items: center; justify-content: center;
    color: var(--brand);}
.f-trust-icon svg{width: 16px; height: 16px;}
.f-trust-text strong{display: block; font-size: 12px; color: var(--ink); font-weight: 700;}
.f-trust-text span{font-size: 11px; color: var(--text-muted);}
.footer-pay{padding: 20px 0;
    border-bottom: 1px solid var(--border);
    display: flex;
    align-items: center;
    gap: 20px;}
.footer-pay-label{font-size: 11px; font-weight: 700; color: var(--text-muted);
    text-transform: uppercase; letter-spacing: .08em;
    white-space: nowrap;
    flex-shrink: 0;}
.pay-logos{display: flex; gap: 8px; flex-wrap: wrap; align-items: center;}
.pay-logo{height: 28px; width: auto;
    border-radius: 5px;
    overflow: hidden;
    display: inline-flex;
    flex-shrink: 0;}
.pay-logo svg{height: 28px; width: 46px; display: block;}
.footer-bottom-bar{padding: 18px 0;
    display: flex; justify-content: space-between; align-items: center;
    font-size: 12px; color: var(--text-muted);}
.footer-legal-links{display: flex; gap: 20px;}
.footer-legal-links a{color: var(--brand); text-decoration: none;
    font-size: 12px; font-weight: 700;}
.footer-legal-links a:hover{text-decoration: underline;}
.footer-bottom-bar .heart{color: var(--brand);}
.pay-logo{display:inline-flex; align-items:center; flex-shrink:0; border-radius:5px; overflow:hidden; box-shadow:0 1px 3px rgba(0,0,0,.1);}
.pay-logo svg{display:block;}
.pay-svg{display:block; width:52px; height:36px;}
.pay-logo{display:inline-flex; align-items:center; flex-shrink:0; border-radius:5px; overflow:hidden;}
.m-l2-link{display: block; padding: 10px 24px 10px 36px;
    font-size: 14px; color: var(--ink); text-decoration: none;
    border-bottom: 1px solid var(--border-light);}
.m-l2-link:hover{color: var(--brand); background: var(--brand-softer);}
.m-drawer-footer{padding: 20px 20px 24px; border-top: 1px solid var(--border);}
/* Desktop-only overrides */
@media (min-width:1024px){
.nav-inner{padding-left: 24px !important;}
}
/* Tablet breakpoint */
@media (max-width:1023px){
.footer-trust-row{grid-template-columns:1fr;gap:18px;padding:20px 0;margin-top:24px}
.site-footer{padding:36px 28px 24px}
.footer-grid{grid-template-columns:1fr 1fr;gap:28px}
.footer-brand{grid-column:1/-1;display:grid;grid-template-columns:auto 1fr;gap:24px;align-items:start;padding-bottom:24px;border-bottom:1px solid var(--border);margin-bottom:4px}
.footer-brand svg.as-logo{margin-bottom:0;height:48px}
.footer-brand-text{display:flex;flex-direction:column}
.footer-trust{margin-top:auto}
.footer-col-2{grid-template-columns:1fr 1fr}
.footer-bottom{padding:16px 28px}
.hero-v1{height: 400px; padding-bottom: 44px;}
.hero-v1 .hero-content{padding: 0 36px;}
.hero-v1 .hero-breadcrumb{padding: 12px 36px;}
.hero-v1 .hero-puzzle{width: 360px; height: 360px; right: -30px;}
.site-footer{padding: 40px 28px 0;}
.footer-top{grid-template-columns: 1fr 1fr;
    gap: 28px;}
.f-brand{grid-column: 1 / -1; display: grid; grid-template-columns: auto 1fr; gap: 24px; padding-bottom: 24px; border-bottom: 1px solid var(--border);}
.f-brand svg.as-logo{height: 48px; width: auto; margin-bottom: 0;}
.f-trust{grid-column: 1 / -1;}
.f-trust-list{flex-direction: row; flex-wrap: wrap; gap: 8px;}
.f-trust-item{flex: 1 1 calc(50% - 8px);}
.footer-pay{gap: 12px;}
.footer-bottom-bar{flex-direction: column; gap: 8px; text-align: center;}
.footer-legal-links{justify-content: center;}
.f-brand{grid-column: 1 / -1 !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 10px;
    padding-bottom: 24px;
    border-bottom: 1px solid var(--border);}
.f-brand svg.as-logo{height: 44px; width: auto;}
.f-brand .f-tagline{margin-top: 4px;}
.f-brand{grid-column: 1 / -1 !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: flex-start !important;
    gap: 8px;
    padding-bottom: 24px;
    border-bottom: 1px solid var(--border);}
.f-brand svg.as-logo{height: 40px; width: auto;}
.hero-v1{justify-content: flex-end;
    padding-bottom: 44px;}
.hero-v1 .hero-breadcrumb{padding-top: 16px;
    padding-bottom: 0;}
.hero-v1 .hero-content{margin-top: auto;}
.f-brand{grid-column: 1 / -1 !important;
    display: grid !important;
    grid-template-columns: auto 1fr !important;
    grid-template-rows: auto auto auto !important;
    column-gap: 20px !important;
    row-gap: 0 !important;
    align-items: start !important;
    padding-bottom: 24px !important;
    border-bottom: 1px solid var(--border) !important;
    margin-bottom: 4px !important;
    flex-direction: unset !important;}
.f-brand svg.as-logo{grid-column: 1 !important;
    grid-row: 1 / span 3 !important;
    height: 52px !important;
    width: auto !important;
    margin: 0 !important;
    display: block !important;
    align-self: start !important;
    margin-bottom: 0 !important;}
.f-brand .f-tagline{grid-column: 2 !important;
    grid-row: 1 !important;
    margin: 2px 0 6px !important;
    align-self: center !important;
    font-size: 14px !important;
    font-weight: 700 !important;}
.f-brand .f-address{grid-column: 2 !important;
    grid-row: 2 !important;
    margin: 0 0 8px !important;}
.f-brand .f-contact{grid-column: 2 !important;
    grid-row: 3 !important;}
.t-top{padding-left: 18px !important;}
}
/* Mobile breakpoint */
@media (max-width:767px){
.footer-trust-row{grid-template-columns:1fr;gap:16px;padding:18px 0;margin-top:20px}
.badge-pill{font-size:10px;padding:6px 10px}
.pay{height:24px;min-width:38px;font-size:9px;padding:0 8px}
.site-footer{padding:28px 20px 20px}
.footer-grid{grid-template-columns:1fr;gap:28px}
.footer-brand svg.as-logo{height:48px}
.footer-col-2{grid-template-columns:1fr}
.footer-legal{flex-direction:column;gap:12px;margin-top:28px}
.footer-bottom{flex-direction:column;gap:8px;padding:14px 20px;text-align:center}
.dummy-body{padding:28px 20px}
.hero-v1{height: 340px; padding-bottom: 32px;}
.hero-v1 .hero-content{padding: 0 20px; max-width: 100%;}
.hero-v1 .hero-breadcrumb{padding: 10px 20px; font-size: 11px;}
.hero-v1 h1{font-size: 22px; margin-bottom: 10px;}
.hero-v1 .hero-sub{font-size: 13px; margin-bottom: 18px;}
.hero-v1 .hero-cta{padding: 10px 20px; font-size: 12px;}
.hero-v1 .hero-puzzle{display: none;}
.site-footer{padding: 32px 20px 0;}
.footer-top{grid-template-columns: 1fr; gap: 24px;}
.f-trust-list{flex-direction: column; gap: 8px;}
.footer-pay{flex-direction: column; align-items: flex-start; gap: 12px;}
.pay-logos{gap: 6px;}
.pay-logo svg{height: 24px; width: 40px;}
.footer-bottom-bar{flex-direction: column; gap: 8px; font-size: 11px; padding: 14px 0;}
.footer-legal-links{justify-content: center; gap: 14px;}
.pay-logo svg{height:24px; width:auto;}
.pay-svg{width:44px; height:30px;}
.f-brand svg.as-logo{height: 32px !important; width: auto;}
.f-brand svg.as-logo{height: 32px !important;
    width: auto !important;}
.f-brand .f-tagline{font-size: 12.5px !important;
    margin: 8px 0 4px !important;}
.m-nav-inner{padding-left: 16px !important;}
}

/* === AS_THEME_V2_HELPERS === */
/* Preview/production nav variant switcher */
.vp-desktop { display: block; }
.vp-tablet, .vp-mobile { display: none; }
@media (max-width: 1023px) and (min-width: 768px) {
  .vp-desktop { display: none; }
  .vp-tablet { display: block; }
}
@media (max-width: 767px) {
  .vp-desktop { display: none; }
  .vp-mobile { display: block; }
}

/* Logo/pay-logo sizing (img replaces SVG) */
.as-logo { height: 36px; width: auto; display: block; }
.brand-bar .as-logo { height: 24px; }
.pay-svg { height: 32px; width: auto; display: block; object-fit: contain; }

/* Hard-kill any leftover parent-theme chrome on front/singular pages with our body class */
body.as-navfoot-active header.c27-main-header,
body.as-navfoot-active .c27-main-header,
body.as-navfoot-active .c27-header-top-bar,
body.as-navfoot-active #site-header,
body.as-navfoot-active .ml-page-header,
body.as-navfoot-active .ml-listing-header-wrap {
  display: none !important;
  visibility: hidden !important;
  height: 0 !important;
}
/* === END AS_THEME_V2_HELPERS === */
