/*
Theme Name: D'haus Care
Theme URI: https://dhaus.vn/care
Author: D'Haus / SNT Group
Author URI: https://dhaus.vn
Description: Theme WordPress cho Trung tâm Bảo hành & Dịch vụ chính hãng D'haus Care. Bao gồm kích hoạt bảo hành, tra cứu bảo hành, hệ thống trạm bảo hành và chính sách. Thiết kế premium cho thiết bị nhà bếp & gia dụng cao cấp (Caso, Thermos, Trotec, Instant Pot, Wilit).
Version: 1.1.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: dhaus-care
*/

/* ============================================================
   DESIGN TOKENS
   Palette: ink (structural trust) + brass (premium metal) + porcelain
   Type:    Be Vietnam Pro (Vietnamese-first) + JetBrains Mono (serial/codes)
   Signature: the digital warranty passport card
   ============================================================ */
:root{
  /* Navy-on-cream identity derived from the D'haus Care logo (#1D224C on #F4F0E5) */
  --ink:#14182E;          /* deep navy-ink: text + dark surfaces (header/footer) */
  --ink-soft:#1D224C;     /* logo navy: secondary dark surface */
  --ink-line:#2C335C;
  --brass:#1D224C;        /* PRIMARY ACCENT = logo navy (buttons, links, focus) */
  --brass-deep:#161B3B;   /* darker navy for hover / text accents */
  --brass-soft:#C9A86A;   /* warm gold: metallic highlight on dark surfaces only */
  --gold:#B08A4F;         /* deeper gold for the warranty-passport chip */
  --navy-soft:#E6E8F1;    /* pale navy tint for soft fills/borders on light bg */
  --porcelain:#F4F0E5;    /* logo cream background */
  --paper:#FFFFFF;
  --slate:#565B70;
  --slate-soft:#83889B;
  --line:#E5E1D6;
  --line-strong:#D6D1C4;
  --valid:#1F7A55;
  --valid-soft:#E4F1EA;
  --expired:#B23B3B;
  --expired-soft:#F6E6E5;
  --pending:#9A6B12;
  --pending-soft:#F6EEDB;

  --font-sans:"Be Vietnam Pro",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;
  --font-mono:"JetBrains Mono","SFMono-Regular",Consolas,monospace;

  --wrap:1180px;
  --radius:14px;
  --radius-sm:9px;
  --shadow-sm:0 1px 2px rgba(20,24,46,.05),0 2px 8px rgba(20,24,46,.04);
  --shadow-md:0 10px 30px rgba(20,24,46,.09),0 2px 8px rgba(20,24,46,.05);
  --shadow-lg:0 24px 60px rgba(20,24,46,.18);
  --ease:cubic-bezier(.2,.7,.2,1);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--font-sans);
  color:var(--ink);
  background:var(--porcelain);
  font-size:16px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}
h1,h2,h3,h4{font-weight:800;line-height:1.12;letter-spacing:-.02em;margin:0}
p{margin:0}

.wrap{max-width:var(--wrap);margin:0 auto;padding:0 24px}
.eyebrow{
  font-family:var(--font-mono);
  font-size:12px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;
  color:var(--brass-deep);display:inline-flex;align-items:center;gap:9px;
}
.eyebrow::before{content:"";width:22px;height:1.5px;background:var(--brass);display:inline-block}
.mono{font-family:var(--font-mono);font-variant-ligatures:none}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:9px;
  padding:14px 26px;border-radius:999px;font-weight:700;font-size:15px;
  border:1.5px solid transparent;transition:transform .25s var(--ease),background .2s,box-shadow .25s,color .2s;
  white-space:nowrap;
}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--brass);color:#fff;box-shadow:0 8px 22px rgba(29,34,76,.30)}
.btn-primary:hover{background:var(--brass-deep);box-shadow:0 12px 30px rgba(22,27,59,.40)}
.btn-dark{background:var(--ink);color:#fff}
.btn-dark:hover{background:#000}
.btn-ghost{background:transparent;border-color:var(--line-strong);color:var(--ink)}
.btn-ghost:hover{border-color:var(--ink);background:var(--ink);color:#fff}
.btn-ghost-light{background:transparent;border-color:rgba(255,255,255,.28);color:#fff}
.btn-ghost-light:hover{background:#fff;color:var(--ink)}
.btn .ico{width:17px;height:17px;stroke:currentColor;fill:none;stroke-width:2}

/* ============================================================
   HEADER
   ============================================================ */
.site-topbar{background:var(--ink);color:#cfd2d8;font-size:12.5px}
.site-topbar .wrap{display:flex;justify-content:space-between;align-items:center;height:38px;gap:16px}
.site-topbar a:hover{color:#fff}
.topbar-contact{display:flex;gap:22px;align-items:center}
.topbar-contact .mono{color:var(--brass-soft);font-weight:500}
.topbar-meta{display:flex;gap:18px;align-items:center;color:var(--slate-soft)}

.site-header{
  position:sticky;top:0;z-index:50;background:rgba(246,244,239,.86);
  backdrop-filter:saturate(140%) blur(12px);border-bottom:1px solid var(--line);
}
.site-header .wrap{display:flex;align-items:center;justify-content:space-between;height:74px;gap:24px}
.brand{display:flex;align-items:center;gap:13px}
.brand-mark-img{width:42px;height:auto;flex:none;display:block}
.brand-name{display:flex;flex-direction:column;line-height:1.05}
.brand-name b{font-size:18px;font-weight:800;letter-spacing:-.02em;color:var(--ink)}
.brand-name b .accent{color:var(--brass)}
.brand-name span{font-family:var(--font-mono);font-size:10px;letter-spacing:.18em;color:var(--slate);text-transform:uppercase}

.main-nav{display:flex;align-items:center;gap:4px;list-style:none;margin:0;padding:0}
.main-nav li{list-style:none;margin:0}
.main-nav a{padding:9px 14px;border-radius:8px;font-weight:500;font-size:14.5px;color:var(--ink-soft);transition:.18s}
.main-nav a:hover,.main-nav .current-menu-item>a{background:rgba(21,23,28,.06);color:var(--ink)}
.header-cta{display:flex;align-items:center;gap:10px}
.nav-toggle{display:none;background:none;border:0;padding:8px}
.nav-toggle svg{width:26px;height:26px;stroke:var(--ink);fill:none;stroke-width:2}

/* ============================================================
   HERO  — signature: warranty passport card
   ============================================================ */
.hero{background:var(--porcelain);position:relative;overflow:hidden;padding:64px 0 72px}
.hero::before{content:"";position:absolute;top:-120px;right:-160px;width:520px;height:520px;
  background:radial-gradient(circle,rgba(174,124,74,.13),transparent 68%);pointer-events:none}
.hero .wrap{display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center;position:relative}
.hero-copy h1{font-size:clamp(34px,4.6vw,56px);margin:20px 0 0}
.hero-copy h1 em{font-style:normal;color:var(--brass-deep)}
.hero-lede{font-size:18px;color:var(--slate);margin-top:20px;max-width:30em}
.hero-actions{display:flex;gap:14px;margin-top:30px;flex-wrap:wrap}
.hero-trust{display:flex;gap:30px;margin-top:34px;padding-top:26px;border-top:1px solid var(--line)}
.hero-trust .num{font-size:26px;font-weight:800;letter-spacing:-.03em}
.hero-trust .num b{color:var(--brass-deep)}
.hero-trust .lbl{font-size:12.5px;color:var(--slate);margin-top:2px}

/* Passport card */
.passport{
  background:var(--ink);color:#fff;border-radius:20px;padding:30px 30px 26px;position:relative;
  box-shadow:var(--shadow-lg);overflow:hidden;transform:rotate(-1.4deg);
}
.passport::before{content:"";position:absolute;inset:0;
  background:radial-gradient(120% 90% at 100% 0%,rgba(174,124,74,.32),transparent 55%)}
.passport>*{position:relative}
.passport-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:26px}
.passport-brandrow{display:flex;align-items:center;gap:10px}
.passport-logo{width:26px;height:auto;opacity:.95;flex:none}
.passport-chip{width:38px;height:30px;border-radius:6px;
  background:linear-gradient(135deg,#d9b27e,#a9743f);position:relative}
.passport-chip::after{content:"";position:absolute;inset:6px;border:1px solid rgba(0,0,0,.25);border-radius:3px}
.passport-label{font-family:var(--font-mono);font-size:10px;letter-spacing:.2em;color:#9aa0ab;text-transform:uppercase}
.passport-status{font-family:var(--font-mono);font-size:11px;font-weight:600;padding:6px 12px;border-radius:999px;
  background:rgba(31,122,85,.18);color:#5fd6a0;border:1px solid rgba(95,214,160,.3);display:inline-flex;align-items:center;gap:7px}
.passport-status .dot{width:7px;height:7px;border-radius:50%;background:#5fd6a0;box-shadow:0 0 0 3px rgba(95,214,160,.2)}
.passport h3{font-size:22px;margin-bottom:4px}
.passport .sub{color:#9aa0ab;font-size:13.5px}
.passport-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px 22px;margin-top:24px;
  padding-top:22px;border-top:1px dashed var(--ink-line)}
.passport-grid .k{font-family:var(--font-mono);font-size:10px;letter-spacing:.14em;color:#787e89;text-transform:uppercase}
.passport-grid .v{font-size:15px;font-weight:600;margin-top:3px}
.passport-grid .v.mono{font-family:var(--font-mono);font-weight:500;letter-spacing:.02em}
.passport-foot{display:flex;justify-content:space-between;align-items:center;margin-top:24px;
  padding-top:18px;border-top:1px solid var(--ink-line)}
.passport-bars{display:flex;gap:3px}
.passport-bars i{width:2.5px;height:26px;background:#5b606b;display:block}
.passport-bars i:nth-child(3n){height:18px}.passport-bars i:nth-child(4n){height:30px}.passport-bars i:nth-child(2n){background:#fff}

/* ============================================================
   BRAND STRIP
   ============================================================ */
.brandstrip{background:var(--ink);color:#fff;padding:30px 0}
.brandstrip .wrap{display:flex;align-items:center;gap:36px;flex-wrap:wrap;justify-content:center}
.brandstrip .label{font-family:var(--font-mono);font-size:11px;letter-spacing:.2em;color:#787e89;text-transform:uppercase}
.brandstrip .logos{display:flex;gap:34px;flex-wrap:wrap;align-items:center;justify-content:center}
.brandstrip .logos span{font-weight:800;font-size:18px;letter-spacing:-.01em;color:#e9e6df;opacity:.85;transition:.2s}
.brandstrip .logos span:hover{opacity:1;color:var(--brass-soft)}

/* ============================================================
   SECTION SHELL
   ============================================================ */
.section{padding:84px 0}
.section.alt{background:var(--paper)}
.section-head{max-width:680px;margin-bottom:46px}
.section-head h2{font-size:clamp(28px,3.4vw,40px);margin:16px 0 0}
.section-head p{color:var(--slate);font-size:17px;margin-top:14px}
.section-head.center{margin-left:auto;margin-right:auto;text-align:center}
.section-head.center .eyebrow{justify-content:center}

/* Quick actions */
.actions-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.action-card{
  background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:28px;
  transition:transform .3s var(--ease),box-shadow .3s,border-color .3s;position:relative;overflow:hidden;
}
.action-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--brass-soft)}
.action-card .ai{width:50px;height:50px;border-radius:12px;background:var(--porcelain);
  display:grid;place-items:center;margin-bottom:18px}
.action-card .ai svg{width:24px;height:24px;stroke:var(--brass-deep);fill:none;stroke-width:1.8}
.action-card h3{font-size:19px;margin-bottom:8px}
.action-card p{color:var(--slate);font-size:14.5px}
.action-card .go{margin-top:18px;display:inline-flex;align-items:center;gap:7px;font-weight:700;font-size:14px;color:var(--brass-deep)}
.action-card .go svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:2;transition:transform .25s}
.action-card:hover .go svg{transform:translateX(4px)}

/* Process steps (numbered = real sequence) */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:0;counter-reset:step}
.step{padding:0 26px 0 0;position:relative}
.step:not(:last-child)::after{content:"";position:absolute;top:21px;right:14px;left:64px;height:1.5px;
  background:repeating-linear-gradient(90deg,var(--line-strong) 0 6px,transparent 6px 12px)}
.step .n{width:44px;height:44px;border-radius:50%;border:1.5px solid var(--brass);color:var(--brass-deep);
  display:grid;place-items:center;font-family:var(--font-mono);font-weight:600;font-size:15px;
  background:var(--porcelain);position:relative;z-index:1}
.section.alt .step .n{background:var(--paper)}
.step h4{font-size:17px;margin:18px 0 7px}
.step p{color:var(--slate);font-size:14px}

/* Service cards */
.services{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.service{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:26px;transition:.3s}
.service:hover{border-color:var(--brass-soft);box-shadow:var(--shadow-sm)}
.service .si{width:46px;height:46px;border-radius:11px;background:var(--ink);display:grid;place-items:center;margin-bottom:16px}
.service .si svg{width:22px;height:22px;stroke:var(--brass-soft);fill:none;stroke-width:1.7}
.service h3{font-size:18px;margin-bottom:8px}
.service p{color:var(--slate);font-size:14.5px}

/* Stats band */
.statband{background:var(--ink);color:#fff;padding:64px 0}
.statband .grid{display:grid;grid-template-columns:repeat(4,1fr);gap:30px;text-align:center}
.statband .num{font-size:clamp(34px,4vw,48px);font-weight:800;letter-spacing:-.03em}
.statband .num b{color:var(--brass)}
.statband .lbl{color:#9aa0ab;font-size:14px;margin-top:8px}
.statband .divider{height:1px;background:var(--ink-line);margin:0 0 44px;max-width:var(--wrap)}

/* Centers */
.centers-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(330px,1fr));gap:22px}
.center-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;transition:.3s}
.center-card:hover{box-shadow:var(--shadow-md);transform:translateY(-3px)}
.center-card .city{background:var(--ink);color:#fff;padding:8px 18px;font-family:var(--font-mono);
  font-size:11px;letter-spacing:.16em;text-transform:uppercase;display:flex;justify-content:space-between;align-items:center}
.center-card .city .tag{color:var(--brass-soft)}
.center-card .body{padding:22px}
.center-card h3{font-size:18px;margin-bottom:12px}
.center-card .row{display:flex;gap:11px;align-items:flex-start;margin-bottom:10px;font-size:14px;color:var(--slate)}
.center-card .row svg{width:17px;height:17px;stroke:var(--brass-deep);fill:none;stroke-width:1.8;flex:none;margin-top:2px}
.center-card .row b{color:var(--ink);font-weight:600}
.center-card .foot{display:flex;gap:10px;margin-top:16px;padding-top:16px;border-top:1px solid var(--line)}
.center-card .foot a{flex:1;text-align:center;padding:10px;border-radius:8px;font-size:13.5px;font-weight:700;
  border:1px solid var(--line-strong);transition:.2s}
.center-card .foot a:hover{background:var(--ink);color:#fff;border-color:var(--ink)}

/* Filter pills */
.city-filter{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:30px}
.city-filter button{padding:9px 18px;border-radius:999px;border:1px solid var(--line-strong);background:var(--paper);
  font-weight:600;font-size:14px;color:var(--ink-soft);transition:.2s}
.city-filter button:hover{border-color:var(--brass)}
.city-filter button.active{background:var(--ink);color:#fff;border-color:var(--ink)}

/* ============================================================
   FORMS  — activation & lookup
   ============================================================ */
.formwrap{display:grid;grid-template-columns:1.1fr .9fr;gap:48px;align-items:start}
.formcard{background:var(--paper);border:1px solid var(--line);border-radius:18px;padding:34px;box-shadow:var(--shadow-sm)}
.formcard h2{font-size:24px;margin-bottom:6px}
.formcard .desc{color:var(--slate);font-size:14.5px;margin-bottom:24px}
.field{margin-bottom:18px}
.field label{display:block;font-size:13px;font-weight:600;margin-bottom:7px;color:var(--ink-soft)}
.field label .req{color:var(--expired)}
.field input,.field select,.field textarea{
  width:100%;padding:13px 15px;border:1.5px solid var(--line-strong);border-radius:var(--radius-sm);
  font-family:inherit;font-size:15px;color:var(--ink);background:var(--paper);transition:.18s;
}
.field input.mono{font-family:var(--font-mono);letter-spacing:.04em}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--brass);
  box-shadow:0 0 0 4px rgba(174,124,74,.12)}
.field .hint{font-size:12.5px;color:var(--slate-soft);margin-top:6px}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-submit{width:100%;margin-top:8px}
.form-aside{position:sticky;top:96px}
.form-aside .note{background:var(--ink);color:#fff;border-radius:16px;padding:28px}
.form-aside .note h3{font-size:18px;margin-bottom:14px}
.form-aside .note ul{list-style:none;padding:0;margin:0}
.form-aside .note li{display:flex;gap:11px;align-items:flex-start;color:#c9ccd2;font-size:14px;margin-bottom:13px}
.form-aside .note li svg{width:18px;height:18px;stroke:var(--brass-soft);fill:none;stroke-width:2;flex:none;margin-top:2px}

/* alerts / results */
.alert{border-radius:var(--radius-sm);padding:14px 16px;font-size:14px;margin-bottom:18px;display:none;gap:10px;align-items:flex-start}
.alert svg{width:18px;height:18px;flex:none;margin-top:1px;stroke-width:2;fill:none}
.alert.show{display:flex}
.alert.ok{background:var(--valid-soft);color:#155c40;border:1px solid #b9ddc9}
.alert.ok svg{stroke:#1f7a55}
.alert.err{background:var(--expired-soft);color:#8f2c2c;border:1px solid #ecc4c2}
.alert.err svg{stroke:#b23b3b}

/* lookup result passport (light) */
.result-passport{display:none;margin-top:8px}
.result-passport.show{display:block;animation:rise .4s var(--ease)}
@keyframes rise{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}

.status-pill{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-mono);font-size:12px;
  font-weight:600;padding:7px 14px;border-radius:999px}
.status-pill .dot{width:8px;height:8px;border-radius:50%}
.status-pill.valid{background:var(--valid-soft);color:var(--valid)}
.status-pill.valid .dot{background:var(--valid)}
.status-pill.expired{background:var(--expired-soft);color:var(--expired)}
.status-pill.expired .dot{background:var(--expired)}
.status-pill.pending{background:var(--pending-soft);color:var(--pending)}
.status-pill.pending .dot{background:var(--pending)}

.spinner{width:18px;height:18px;border:2.5px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;
  animation:spin .7s linear infinite;display:inline-block}
@keyframes spin{to{transform:rotate(360deg)}}

/* ============================================================
   FAQ / accordion
   ============================================================ */
.faq{max-width:820px;margin:0 auto}
.faq-item{border-bottom:1px solid var(--line)}
.faq-q{width:100%;text-align:left;background:none;border:0;padding:22px 0;display:flex;justify-content:space-between;
  align-items:center;gap:20px;font-size:17px;font-weight:700;color:var(--ink)}
.faq-q .pm{width:26px;height:26px;border-radius:50%;border:1.5px solid var(--line-strong);display:grid;place-items:center;flex:none;transition:.25s}
.faq-q .pm svg{width:14px;height:14px;stroke:var(--ink);fill:none;stroke-width:2;transition:.25s}
.faq-item.open .faq-q .pm{background:var(--brass);border-color:var(--brass)}
.faq-item.open .faq-q .pm svg{stroke:#fff;transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .35s var(--ease)}
.faq-a p{color:var(--slate);padding-bottom:22px;font-size:15px}

/* ============================================================
   CTA banner
   ============================================================ */
.cta-banner{background:var(--ink);color:#fff;border-radius:22px;padding:52px;position:relative;overflow:hidden;
  display:flex;justify-content:space-between;align-items:center;gap:36px;flex-wrap:wrap}
.cta-banner::before{content:"";position:absolute;right:-80px;top:-80px;width:340px;height:340px;
  background:radial-gradient(circle,rgba(174,124,74,.28),transparent 65%)}
.cta-banner>*{position:relative}
.cta-banner h2{font-size:clamp(26px,3vw,36px)}
.cta-banner p{color:#aab0ba;margin-top:12px;max-width:34em}
.cta-banner .acts{display:flex;gap:12px;flex-wrap:wrap}

/* ============================================================
   PAGE HERO (inner)
   ============================================================ */
.page-hero{background:var(--ink);color:#fff;padding:56px 0;position:relative;overflow:hidden}
.page-hero::before{content:"";position:absolute;right:-120px;bottom:-120px;width:380px;height:380px;
  background:radial-gradient(circle,rgba(174,124,74,.22),transparent 65%)}
.page-hero .wrap{position:relative}
.page-hero h1{font-size:clamp(30px,4vw,46px);margin-top:14px}
.page-hero p{color:#aab0ba;font-size:17px;margin-top:14px;max-width:42em}
.breadcrumb{font-family:var(--font-mono);font-size:12px;color:#787e89;letter-spacing:.05em}
.breadcrumb a:hover{color:var(--brass-soft)}
.breadcrumb span{margin:0 8px;color:#4a4f58}

/* policy / prose */
.prose{max-width:760px;margin:0 auto}
.prose h2{font-size:24px;margin:38px 0 14px}
.prose h3{font-size:18px;margin:26px 0 10px}
.prose p{color:#3a3e46;margin-bottom:14px}
.prose ul{padding-left:20px;color:#3a3e46;margin-bottom:16px}
.prose li{margin-bottom:8px}
.policy-table{width:100%;border-collapse:collapse;margin:18px 0;font-size:14.5px}
.policy-table th,.policy-table td{text-align:left;padding:13px 16px;border:1px solid var(--line)}
.policy-table th{background:var(--porcelain);font-weight:700}
.policy-table tr:nth-child(even){background:var(--porcelain)}

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{background:var(--ink);color:#9aa0ab;padding:64px 0 0}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.2fr;gap:40px;padding-bottom:48px}
.footer-grid h4{color:#fff;font-size:14px;letter-spacing:.04em;margin-bottom:18px}
.footer-grid a{display:block;color:#9aa0ab;font-size:14px;padding:6px 0;transition:.18s}
.footer-grid a:hover{color:var(--brass-soft)}
.footer-about p{font-size:14px;line-height:1.7;margin:16px 0 18px;max-width:30em}
.footer-logo{width:148px;height:auto;margin-bottom:4px}
.footer-addr{font-size:13.5px;color:#aeb2c4;margin-top:-4px !important}
.footer-social{display:flex;gap:10px}
.footer-social a{width:38px;height:38px;border-radius:9px;border:1px solid var(--ink-line);display:grid;place-items:center}
.footer-social a:hover{background:var(--brass);border-color:var(--brass)}
.footer-social svg{width:18px;height:18px;stroke:#cfd2d8;fill:none;stroke-width:1.8}
.footer-social a:hover svg{stroke:#fff}
.footer-bottom{border-top:1px solid var(--ink-line);padding:22px 0;display:flex;justify-content:space-between;
  align-items:center;gap:16px;font-size:13px;flex-wrap:wrap}
.footer-bottom .mono{color:#787e89}

/* hotline float */
.hotline-float{position:fixed;right:20px;bottom:20px;z-index:60;display:flex;flex-direction:column;gap:12px}
.hotline-float a{width:54px;height:54px;border-radius:50%;display:grid;place-items:center;box-shadow:var(--shadow-md);transition:transform .2s}
.hotline-float a:hover{transform:scale(1.08)}
.hotline-float .phone{background:var(--brass)}
.hotline-float .zalo{background:#0068FF}
.hotline-float svg{width:26px;height:26px;stroke:#fff;fill:none;stroke-width:2}
.hotline-float .phone{animation:ring 2.4s ease-in-out infinite}
@keyframes ring{0%,100%{box-shadow:0 0 0 0 rgba(174,124,74,.5)}50%{box-shadow:0 0 0 12px rgba(174,124,74,0)}}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:980px){
  .hero .wrap{grid-template-columns:1fr;gap:40px}
  .passport{transform:none;max-width:440px}
  .actions-grid,.services,.statband .grid{grid-template-columns:repeat(2,1fr)}
  .steps{grid-template-columns:repeat(2,1fr);gap:36px 20px}
  .step:not(:last-child)::after{display:none}
  .formwrap{grid-template-columns:1fr;gap:28px}
  .form-aside{position:static}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:680px){
  .main-nav,.topbar-meta{display:none}
  .nav-toggle{display:block}
  .site-header.open .main-nav{display:flex;position:absolute;top:74px;left:0;right:0;flex-direction:column;
    background:var(--porcelain);padding:14px 24px;border-bottom:1px solid var(--line);gap:2px;box-shadow:var(--shadow-md)}
  .site-header.open .main-nav a{padding:13px 14px}
  .actions-grid,.services,.statband .grid,.steps,.field-row,.footer-grid{grid-template-columns:1fr}
  .header-cta .btn-ghost{display:none}
  .hero{padding:40px 0 48px}
  .section{padding:56px 0}
  .cta-banner{padding:34px 26px}
  .passport-grid{grid-template-columns:1fr 1fr}
  .hero-trust{flex-wrap:wrap;gap:20px}
}

/* accessibility */
:focus-visible{outline:2.5px solid var(--brass);outline-offset:2px;border-radius:4px}
@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important;scroll-behavior:auto}}
