﻿/* ─── Reset ──────────────────────────────────────────────────────────────────── */
*,::before,::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --blue:#2563eb;
  --blue-l:#3b82f6;
  --cyan:#0ea5e9;
  --green:#10b981;
  --amber:#f59e0b;
  --purple:#8b5cf6;
  --text:#1e293b;
  --text2:#475569;
  --text3:#64748b;
  --card:rgba(255,255,255,.78);
  --border:rgba(148,163,184,.18);
  --border-blue:rgba(59,130,246,.3);
}
html{scroll-behavior:smooth;font-size:17px}
@media(max-width:560px){html{font-size:15px}}
::selection{background:rgba(253,230,138,.55);color:#7c2d12}
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:rgba(255,255,255,.18);border-radius:6px;border:2px solid transparent;background-clip:padding-box}
::-webkit-scrollbar-thumb:hover{background:rgba(255,255,255,.3);background-clip:padding-box}
body{
  background:#0d2b7e;
  color:var(--text);
  font-family:'Microsoft YaHei','微软雅黑','PingFang SC','Hiragino Sans GB','Helvetica Neue',Arial,sans-serif;
  min-height:100vh;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}

/* ─── Top CTA Bar ───────────────────────────────────────────────────────────── */
.top-cta-wrap{position:sticky;top:0;z-index:2000;padding:16px 20px 0;pointer-events:none;}
.top-cta-bar{background:linear-gradient(130deg,#fff 0%,#fffbeb 100%);border:1px solid rgba(253,191,36,.35);border-radius:14px;display:flex;align-items:center;justify-content:space-between;padding:14px 20px;gap:12px;box-shadow:0 8px 28px rgba(0,0,40,.28),0 2px 8px rgba(251,191,36,.15);max-width:1140px;margin:0 auto;pointer-events:all;}
.top-cta-bar-left{display:flex;align-items:center;gap:10px;}
.top-cta-bar-left i{color:#2563eb;font-size:20px;flex-shrink:0;}
.top-cta-bar-text{font-size:14px;color:#0f172a;font-weight:700;white-space:nowrap;}
.top-cta-bar-sub{font-size:12px;color:#64748b;margin-left:5px;font-weight:400;}
.top-cta-bar-btn{flex-shrink:0;background:linear-gradient(135deg,#1e40af,#2563eb);color:#fff;border:none;border-radius:9px;padding:9px 22px;font-size:13px;font-weight:700;cursor:pointer;text-decoration:none;white-space:nowrap;transition:box-shadow .2s,filter .2s;display:inline-block;box-shadow:0 4px 14px rgba(37,99,235,.4);}
.top-cta-bar-btn:hover{filter:brightness(1.1);box-shadow:0 6px 20px rgba(37,99,235,.55);}
@media(max-width:520px){.top-cta-bar-sub{display:none}.top-cta-wrap{padding:10px 12px 0;}.top-cta-bar{padding:11px 14px;}}

/* ─── Background ─────────────────────────────────────────────────────────────── */
.bg{position:fixed;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.bg-canvas{position:absolute;inset:0;background:linear-gradient(125deg,#1e3a8a 0%,#1d4ed8 28%,#2563eb 54%,#3b82f6 78%,#1e3a8a 100%);background-size:400% 400%;animation:bg-pan 22s ease-in-out infinite}
@keyframes bg-pan{0%{background-position:0% 50%}50%{background-position:100% 50%}100%{background-position:0% 50%}}
.orb{position:absolute;border-radius:50%;filter:blur(72px);pointer-events:none}
.orb-1{width:600px;height:600px;background:radial-gradient(circle,rgba(96,165,250,.52),transparent 70%);top:-240px;left:-200px;animation:orb1 26s ease-in-out infinite}
.orb-2{width:460px;height:460px;background:radial-gradient(circle,rgba(59,130,246,.58),transparent 70%);bottom:-180px;right:-130px;animation:orb2 32s ease-in-out infinite}
.orb-3{width:340px;height:340px;background:radial-gradient(circle,rgba(14,165,233,.48),transparent 70%);top:36%;left:50%;animation:orb3 19s ease-in-out infinite}
.orb-4{width:220px;height:220px;background:radial-gradient(circle,rgba(147,197,253,.42),transparent 70%);top:62%;left:10%;animation:orb4 24s ease-in-out infinite}
/* Aurora orbs — cyan & violet */
.orb-5{width:1100px;height:900px;background:radial-gradient(ellipse,rgba(6,182,212,.50),transparent 55%);top:-120px;right:-180px;filter:blur(90px);animation:orb5 38s ease-in-out infinite}
.orb-6{width:1000px;height:850px;background:radial-gradient(ellipse,rgba(139,92,246,.42),transparent 55%);bottom:-150px;left:-160px;filter:blur(95px);animation:orb6 44s ease-in-out infinite}
/* Breathing keyframes (translate + scale) */
@keyframes orb1{0%,100%{transform:translate(0,0) scale(1)}33%{transform:translate(45px,-32px) scale(1.07)}66%{transform:translate(-28px,22px) scale(.93)}}
@keyframes orb2{0%,100%{transform:translate(0,0) scale(1)}33%{transform:translate(-38px,28px) scale(1.06)}66%{transform:translate(32px,-22px) scale(.94)}}
@keyframes orb3{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(-30px,36px) scale(1.10)}}
@keyframes orb4{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(24px,-30px) scale(1.09)}}
@keyframes orb5{0%,100%{transform:translate(0,0) scale(1)}30%{transform:translate(-90px,70px) scale(1.12)}65%{transform:translate(50px,-55px) scale(.88)}}
@keyframes orb6{0%,100%{transform:translate(0,0) scale(1)}40%{transform:translate(80px,-90px) scale(1.14)}75%{transform:translate(-60px,50px) scale(.90)}}
.bg-dots{position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,.1) 1px,transparent 1px);background-size:28px 28px;opacity:.7}

/* ─── Layout ─────────────────────────────────────────────────────────────────── */
.page{position:relative;max-width:1140px;margin:0 auto;padding:0 32px}
@media(max-width:560px){.page{padding:0 18px}}

/* ─── Main Card ──────────────────────────────────────────────────────────────── */
.main-card{
  max-width:1140px;margin:48px auto 36px;border-radius:20px;overflow:hidden;
  position:relative;z-index:2;
  box-shadow:0 1px 0 rgba(255,255,255,.18) inset,0 30px 90px -20px rgba(0,0,60,.55),0 12px 40px -8px rgba(0,0,60,.3);
}
.main-card>header{
  background:
    radial-gradient(ellipse at 85% 10%,rgba(253,230,138,.16),transparent 50%),
    radial-gradient(ellipse at 10% 95%,rgba(147,197,253,.22),transparent 55%),
    linear-gradient(150deg,#1a3a8f 0%,#1d4ed8 45%,#2563eb 100%);
  padding:48px 36px 64px;position:relative;overflow:hidden;
}
.main-card>header::before{
  content:"";position:absolute;inset:0;
  background-image:radial-gradient(rgba(255,255,255,.08) 1px,transparent 1px);
  background-size:22px 22px;background-position:0 0;opacity:.7;pointer-events:none;
  -webkit-mask-image:linear-gradient(180deg,#000 0%,#000 60%,transparent 100%);
  mask-image:linear-gradient(180deg,#000 0%,#000 60%,transparent 100%);
}
.main-card>header::after{
  content:"";position:absolute;left:0;right:0;bottom:-1px;height:60px;
  background:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1200 60' preserveAspectRatio='none'><path d='M0,30 C200,60 400,0 600,20 C800,40 1000,60 1200,30 L1200,60 L0,60 Z' fill='%23ffffff'/></svg>") center bottom/100% 100% no-repeat;
  pointer-events:none;
}
.main-card>header>.page{position:relative;z-index:1;max-width:100%;padding:0}
.content-wrap{background:#fff;padding:8px 32px 36px;}
@media(max-width:560px){
  .content-wrap{padding:8px 18px 28px}
  .main-card>header{padding:32px 22px 50px}
  .main-card{margin:20px 12px 22px;border-radius:18px}
}

/* ─── Header Content ─────────────────────────────────────────────────────────── */
.hd-logo-row{display:flex;align-items:center;gap:14px;margin-bottom:22px}
.logo-box{
  width:56px;height:56px;border-radius:14px;background:rgba(255,255,255,.95);
  border:1px solid rgba(255,255,255,.4);display:flex;align-items:center;justify-content:center;
  font-size:24px;flex-shrink:0;box-shadow:0 6px 22px rgba(0,0,0,.18),0 0 0 4px rgba(255,255,255,.08);padding:6px;
}
.logo-box .bi{font-size:26px;color:#2563eb}
.logo-img{width:48px;height:48px;border-radius:10px;object-fit:cover;display:block;}
.brand-name{font-size:20px;font-weight:800;letter-spacing:-.2px;color:#fff;text-shadow:0 1px 14px rgba(0,0,0,.2)}
.brand-name b{color:#fde68a;font-weight:inherit;background:none;-webkit-text-fill-color:#fde68a}
.brand-live{display:flex;align-items:center;gap:5px;font-size:11px;color:#fff;margin-top:3px}
.brand-live::before{content:'';width:6px;height:6px;border-radius:50%;background:#34d399;box-shadow:0 0 8px #34d399,0 0 14px rgba(52,211,153,.4)}
.hd-title{font-size:clamp(26px,5vw,40px);font-weight:800;letter-spacing:-.6px;line-height:1.18;color:#fff;text-shadow:0 2px 30px rgba(0,0,0,.25)}
.hd-title mark{background:none;-webkit-text-fill-color:#fde68a;color:#fde68a}
.hd-desc{margin-top:13px;font-size:14px;color:rgba(255,255,255,.88);line-height:1.8;max-width:500px}
.hd-desc a{color:#fde68a;text-decoration:underline;text-underline-offset:3px;font-weight:600}
.hd-desc a:hover{color:#fef3c7}

/* ─── Notice Bar ─────────────────────────────────────────────────────────────── */
.notice-bar{display:flex;align-items:center;background:transparent;border:1.5px dashed rgba(255,255,255,.45);border-radius:10px;cursor:pointer;padding:8px 14px;gap:10px;margin-top:16px;transition:border-color .2s,background .2s;}
.notice-bar:hover{border-color:rgba(255,255,255,.85);background:rgba(255,255,255,.08);}
.notice-bar-icon{flex-shrink:0;color:#fde68a;font-size:15px;animation:nbring .9s ease-in-out infinite alternate;}
@keyframes nbring{0%{transform:rotate(-18deg)}100%{transform:rotate(18deg)}}
.notice-bar-track{flex:1;overflow:hidden;height:22px;position:relative;}
.notice-ticker{position:absolute;top:0;left:0;width:100%;transition:transform .5s cubic-bezier(.22,1,.36,1),opacity .5s;}
.notice-ticker .notice-bar-scroll{font-size:13px;color:rgba(255,255,255,.92);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block;line-height:22px;}
.notice-bar-more{flex-shrink:0;font-size:12px;color:rgba(255,255,255,.7);white-space:nowrap;display:flex;align-items:center;gap:3px;transition:color .2s;}
.notice-bar:hover .notice-bar-more{color:#fde68a;}

/* ─── Notice Modal ───────────────────────────────────────────────────────────── */
.notice-modal-overlay{display:none;position:fixed;inset:0;background:rgba(10,20,60,.62);backdrop-filter:blur(4px);z-index:9999;align-items:center;justify-content:center;padding:20px}
.notice-modal-overlay.open{display:flex}
.notice-modal{background:#fff;border-radius:18px;width:100%;max-width:460px;overflow:hidden;box-shadow:0 24px 60px rgba(0,0,40,.38);animation:nmslide .28s cubic-bezier(.22,1,.36,1)}
@keyframes nmslide{from{transform:translateY(28px);opacity:0}to{transform:translateY(0);opacity:1}}
.notice-modal-head{background:linear-gradient(135deg,#1e3a8a,#2563eb);padding:18px 20px 16px;display:flex;align-items:center;gap:10px}
.notice-modal-head-icon{font-size:22px;color:#fde68a}
.notice-modal-head-title{color:#fff;font-size:16px;font-weight:700;flex:1}
.notice-modal-close{background:rgba(255,255,255,.18);border:none;border-radius:50%;width:28px;height:28px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#fff;font-size:16px;transition:background .2s}
.notice-modal-close:hover{background:rgba(255,255,255,.35)}
.notice-modal-body{padding:20px;line-height:1.85;color:#1e293b;font-size:14px}
.notice-modal-body b{color:#dc2626}
.notice-modal-body .nm-item{display:flex;gap:8px;margin-bottom:10px;align-items:flex-start}
.notice-modal-body .nm-dot{flex-shrink:0;width:6px;height:6px;background:#2563eb;border-radius:50%;margin-top:8px}
.notice-modal-footer{padding:0 20px 18px;display:flex;justify-content:flex-end}
.notice-modal-btn{background:linear-gradient(135deg,#1e40af,#2563eb);color:#fff;border:none;border-radius:10px;padding:9px 22px;font-size:14px;font-weight:600;cursor:pointer;letter-spacing:.3px;transition:filter .2s}
.notice-modal-btn:hover{filter:brightness(1.1)}

/* ─── Device Detect Bar ──────────────────────────────────────────────────────── */
.detect-bar{
  display:none;margin:6px 0 18px;padding:13px 16px;border-radius:11px;
  background:linear-gradient(135deg,#eff6ff,#eef2ff);border:1px solid rgba(59,130,246,.18);
  border-left:3px solid var(--blue-l);align-items:center;gap:12px;
}
.detect-bar.show{display:flex;animation:pop .3s cubic-bezier(.23,1.2,.46,1)}
@keyframes pop{from{transform:scale(.97);opacity:0}to{transform:scale(1);opacity:1}}
.detect-dot{width:7px;height:7px;border-radius:50%;background:var(--cyan);box-shadow:0 0 6px var(--cyan);flex-shrink:0;animation:pulse-dot 2s infinite}
@keyframes pulse-dot{0%,100%{opacity:1}50%{opacity:.35}}
.detect-body{flex:1}
.detect-label{font-size:13px;font-weight:600}
.detect-hint{font-size:11.5px;color:var(--text3);margin-top:2px}
.detect-switch{font-size:11px;color:#2563eb;cursor:pointer;flex-shrink:0;white-space:nowrap}
.detect-switch:hover{text-decoration:underline}

/* ─── Tabs ───────────────────────────────────────────────────────────────────── */
.tabs-wrap{padding:10px 0 0;border-bottom:1px solid var(--border);position:relative}
.tabs{display:flex;gap:4px;flex-wrap:wrap}
.tab{
  padding:14px 22px;border-radius:0;border:none;border-bottom:3px solid transparent;
  background:transparent;color:var(--text3);font-size:16px;font-weight:600;
  cursor:pointer;transition:color .18s,border-color .18s;display:flex;align-items:center;gap:8px;
  white-space:nowrap;user-select:none;margin-bottom:-1px;
}
.tab:hover{color:var(--text2)}
.tab.active{color:var(--blue);border-bottom-color:var(--blue);font-weight:700;}
.tab.active .bi{color:var(--blue)}
@media(max-width:560px){.tab{padding:12px 14px;font-size:15px}.tab .bi{font-size:17px}}

/* ─── Panels ─────────────────────────────────────────────────────────────────── */
.panel{display:none}
.panel.show{display:block;animation:slide-in .22s ease}
@keyframes slide-in{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}
.panel-wrap{padding:30px 0 6px}
.panel-title-row{display:flex;align-items:center;gap:10px;margin-bottom:7px}
.panel-title{font-size:18px;font-weight:700}
.panel-desc{font-size:13.5px;color:var(--text2);margin-bottom:22px;line-height:1.7}
.warn{
  display:flex;align-items:flex-start;gap:11px;padding:13px 15px;border-radius:10px;
  background:rgba(255,251,235,.92);border-left:3px solid rgba(245,158,11,.6);
  border-top:1px solid rgba(245,158,11,.15);border-right:1px solid rgba(245,158,11,.12);
  border-bottom:1px solid rgba(245,158,11,.12);margin-bottom:22px;
}
.warn-title{font-size:12px;font-weight:700;color:#92400e}
.warn-text{font-size:12px;color:#a16207;margin-top:3px;line-height:1.65}
.info-note{
  display:flex;align-items:flex-start;gap:11px;padding:13px 15px;border-radius:10px;
  background:rgba(236,254,255,.9);border-left:3px solid rgba(6,182,212,.55);
  border-top:1px solid rgba(6,182,212,.15);border-right:1px solid rgba(6,182,212,.12);
  border-bottom:1px solid rgba(6,182,212,.12);margin-bottom:22px;
}
.info-note-title{font-size:12px;font-weight:700;color:#0e7490}
.info-note-text{font-size:12px;color:#155e75;margin-top:3px;line-height:1.65}
.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(380px,1fr));gap:16px}
@media(max-width:640px){.cards{grid-template-columns:1fr}}

/* ─── Cards ──────────────────────────────────────────────────────────────────── */
.card{
  border-radius:14px;border:1px solid rgba(148,163,184,.22);background:#fff;overflow:hidden;
  transition:border-color .22s,box-shadow .22s,transform .22s;
  box-shadow:0 1px 3px rgba(15,23,42,.06),0 4px 18px rgba(15,23,42,.04);position:relative;
}
.card::before{
  content:'';position:absolute;top:0;left:0;width:3px;bottom:0;
  background:linear-gradient(180deg,rgba(59,130,246,.5),rgba(139,92,246,.3));opacity:0;transition:opacity .2s;
}
.card:hover{border-color:rgba(59,130,246,.35);box-shadow:0 4px 12px rgba(37,99,235,.08),0 14px 40px rgba(37,99,235,.16);transform:translateY(-3px);}
.card:hover::before{opacity:1}
.card-top{padding:20px 20px 0;display:flex;gap:14px}
.card-app-icon{width:52px;height:52px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:26px;flex-shrink:0;box-shadow:0 4px 16px rgba(0,0,0,.3);}
.app-icon-img{width:52px;height:52px;border-radius:14px;object-fit:cover;flex-shrink:0;display:block;box-shadow:0 3px 14px rgba(0,0,0,.12);}
.card-info{flex:1;min-width:0;padding-top:2px}
.card-name{font-size:15px;font-weight:700;display:flex;align-items:center;gap:7px;flex-wrap:wrap;line-height:1.3}
.badge{font-size:10px;padding:2px 7px;border-radius:4px;font-weight:600;flex-shrink:0}
.badge-rec{background:rgba(209,250,229,.75);border:1px solid rgba(16,185,129,.3);color:#047857}
.badge-adv{background:rgba(254,243,199,.8);border:1px solid rgba(245,158,11,.3);color:#b45309}
.badge-open{background:rgba(237,233,254,.75);border:1px solid rgba(139,92,246,.28);color:#6d28d9}
.badge-apk{background:rgba(207,250,254,.75);border:1px solid rgba(6,182,212,.3);color:#0e7490}
.badge-chip{background:rgba(224,231,255,.75);border:1px solid rgba(99,102,241,.28);color:#4338ca}
.badge-arch{font-size:11px;padding:3px 9px;border-radius:5px;font-weight:800;letter-spacing:.2px;display:inline-flex;align-items:center;gap:4px}
.badge-arch .bi{font-size:12px}
.badge-arch-m{background:linear-gradient(135deg,#fdf2f8,#ede9fe);border:1px solid rgba(168,85,247,.45);color:#6b21a8;box-shadow:0 1px 3px rgba(168,85,247,.18)}
.badge-arch-i{background:linear-gradient(135deg,#eff6ff,#dbeafe);border:1px solid rgba(59,130,246,.5);color:#1d4ed8;box-shadow:0 1px 3px rgba(59,130,246,.2)}
.card-desc{font-size:12.5px;color:var(--text2);margin-top:5px;line-height:1.6}
.card-desc b.arch-m{color:#7e22ce;font-weight:800}
.card-desc b.arch-i{color:#1d4ed8;font-weight:800}
.card-notice{font-size:11.5px;color:#d97706;margin-top:5px;line-height:1.5}
.card-divider{margin:16px 20px 0;height:1px;background:var(--border)}
.card-btns{padding:14px 20px 18px;display:flex;gap:9px;flex-wrap:wrap}
.btn{
  flex:1;min-width:120px;display:inline-flex;align-items:center;justify-content:center;gap:7px;
  padding:11px 18px;border-radius:10px;font-size:13px;font-weight:600;text-decoration:none;
  transition:opacity .15s,transform .15s,box-shadow .15s;cursor:pointer;border:none;white-space:nowrap;
}
.btn:hover{opacity:.88;transform:translateY(-1px)}
.btn:active{transform:scale(.98)}
.btn-dl{background:linear-gradient(135deg,#1e40af,#2563eb);color:#fff;box-shadow:0 4px 14px rgba(37,99,235,.35),inset 0 1px 0 rgba(255,255,255,.18);}
.btn-dl:hover{box-shadow:0 6px 20px rgba(37,99,235,.45),inset 0 1px 0 rgba(255,255,255,.18)}
.btn-tut{background:rgba(220,252,231,.75);border:1px solid rgba(16,185,129,.28);color:#047857;}
.btn-tut:hover{background:rgba(187,247,208,.9)}

/* ─── Lower Section ──────────────────────────────────────────────────────────── */
.lower-section{padding:8px 0 50px;position:relative;z-index:1}
.lower-section>.page{padding-left:0;padding-right:0}
@media(max-width:560px){.lower-section>.page{padding-left:12px;padding-right:12px}}
.bottom-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:24px}
@media(max-width:620px){.bottom-row{grid-template-columns:1fr}}
.faq-card,.contact-card{
  border-radius:18px;border:1px solid rgba(255,255,255,.4);background:#fff;
  padding:24px;
  box-shadow:0 12px 40px rgba(0,0,40,.2),0 2px 8px rgba(0,0,40,.06);
}
.section-label{font-size:11px;font-weight:700;color:#64748b;margin-bottom:16px;text-transform:uppercase;letter-spacing:1px}
.faq-item{margin-bottom:14px}
.faq-item:last-child{margin-bottom:0}
.faq-q{font-size:13.5px;font-weight:600;color:#0f172a;margin-bottom:4px}
.faq-a{font-size:12.5px;color:#64748b;margin-top:3px;line-height:1.7}
.faq-item.highlight{position:relative;background:linear-gradient(135deg,rgba(239,68,68,.14),rgba(245,158,11,.12));border:1px solid rgba(239,68,68,.45);border-radius:12px;padding:12px 14px;margin-bottom:14px;box-shadow:0 0 0 1px rgba(239,68,68,.12),0 6px 18px -6px rgba(239,68,68,.35)}
.faq-item.highlight .faq-q{color:#b91c1c;display:flex;align-items:center;gap:6px}
.faq-item.highlight .faq-q i{color:#dc2626}
.faq-item.highlight .faq-a{color:#7f1d1d}
.faq-item.highlight .faq-link{display:inline-block;margin-top:6px;padding:6px 12px;background:#dc2626;color:#fff;font-weight:700;border-radius:8px;text-decoration:none;font-size:13px;letter-spacing:.3px}
.faq-item.highlight .faq-link:hover{background:#b91c1c;color:#fff}
.contact-link{
  display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:12px;
  border:1px solid rgba(15,23,42,.08);background:rgba(248,250,252,.7);
  text-decoration:none;transition:background .2s,border-color .2s,transform .2s;margin-bottom:10px;
}
.contact-link:last-child{margin-bottom:0}
.contact-link:hover{background:#eff6ff;border-color:rgba(37,99,235,.35);transform:translateX(3px)}
.contact-ico{font-size:20px;flex-shrink:0;width:38px;height:38px;display:flex;align-items:center;justify-content:center;border-radius:10px;background:linear-gradient(135deg,#eff6ff,#dbeafe);border:1px solid rgba(37,99,235,.18);color:#2563eb}
.contact-name{font-size:13.5px;font-weight:600;color:#0f172a}
.contact-sub{font-size:11.5px;color:#64748b;margin-top:2px}
.contact-arr{margin-left:auto;color:#94a3b8;font-size:16px}

/* ─── Footer ─────────────────────────────────────────────────────────────────── */
footer{border-top:1px solid rgba(255,255,255,.12);padding:30px 0 36px;margin-top:56px;}
.footer-inner{display:flex;align-items:flex-start;justify-content:space-between;gap:20px;flex-wrap:wrap}
.footer-name{font-size:17px;font-weight:800;color:#fff}
.footer-name b{background:linear-gradient(90deg,#93c5fd,#7dd3fc);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-weight:inherit}
.footer-slogan{font-size:13px;color:rgba(255,255,255,.85);margin-top:6px;font-weight:500}
.footer-links{display:flex;gap:22px;flex-wrap:wrap;align-items:center}
.footer-links a{font-size:13px;color:rgba(255,255,255,.92);text-decoration:none;font-weight:500}
.footer-links a:hover{color:#fde68a}
.footer-copy{width:100%;font-size:12px;color:rgba(255,255,255,.65);margin-top:18px}

/* ─── Bootstrap Icons overrides ──────────────────────────────────────────────── */
.bi{font-size:inherit;vertical-align:-.12em;line-height:1;display:inline-block}
.btn .bi{font-size:13px}
.tab .bi{font-size:18px}
.warn .bi,.info-note .bi{font-size:14px;flex-shrink:0;margin-top:2px}
.ptitle-icon-i{font-size:20px;line-height:1;color:var(--blue)}