/* =============================================================
   Mokan Travel Connect - bookmokan.com
   Technical B2B theme: white / gray / blue accent
   ============================================================= */

:root {
  --navy:      #0d1b2a;
  --navy-2:    #13294b;
  --navy-3:    #1c3a63;
  --blue:      #2f6fed;
  --blue-600:  #1d4ed8;
  --blue-700:  #1e40af;
  --sky:       #3b82f6;
  --sky-soft:  #dbeafe;
  --ink:       #0f172a;
  --slate:     #475569;
  --slate-2:   #64748b;
  --slate-300: #cbd5e1;
  --line:      #e6ebf2;
  --line-2:    #eef2f7;
  --bg:        #ffffff;
  --bg-soft:   #f6f8fc;
  --bg-soft-2: #eef3fa;
  --code-bg:   #0b1426;
  --code-line: #1e2d49;
  --green:     #16a34a;
  --amber:     #d97706;
  --radius:    14px;
  --radius-sm: 10px;
  --shadow-sm: 0 1px 2px rgba(15,23,42,.06), 0 1px 3px rgba(15,23,42,.04);
  --shadow:    0 10px 30px -12px rgba(15,23,42,.18);
  --shadow-lg: 0 24px 60px -20px rgba(13,27,42,.35);
  --mono: ui-monospace, "SFMono-Regular", "JetBrains Mono", "Cascadia Code", Consolas, "Liberation Mono", Menlo, monospace;
  --sans: system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, "Noto Sans", sans-serif;
}

* { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
  font-family: var(--sans);
  color: var(--ink);
  background: var(--bg);
  font-size: 1.02rem;
  line-height: 1.65;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

.container { max-width: 1180px; }

h1, h2, h3, h4 { font-weight: 700; letter-spacing: -0.02em; color: var(--ink); line-height: 1.18; }
h1 { font-size: clamp(2.1rem, 4.4vw, 3.25rem); }
h2 { font-size: clamp(1.65rem, 3vw, 2.3rem); }
h3 { font-size: 1.3rem; }
a { color: var(--blue-600); text-decoration: none; }
a:hover { color: var(--blue-700); text-decoration: underline; }
p { color: var(--slate); }
hr { border-color: var(--line); opacity: 1; }

.skip-link {
  position: absolute; left: 1rem; top: .5rem; z-index: 2000;
  background: var(--navy); color: #fff; padding: .5rem .9rem; border-radius: 8px;
}

/* ---------- Eyebrow + section helpers ---------- */
.eyebrow {
  display: inline-flex; align-items: center; gap: .5rem;
  font: 600 .8rem/1 var(--mono);
  letter-spacing: .12em; text-transform: uppercase;
  color: var(--blue-600); margin-bottom: .85rem;
}
.eyebrow::before { content: ""; width: 1.6rem; height: 2px; background: var(--blue); display: inline-block; }
.section { padding: clamp(3.5rem, 7vw, 6rem) 0; }
.section-soft { background: var(--bg-soft); }
.section-navy { background: var(--navy); color: #fff; }
.section-navy h1, .section-navy h2, .section-navy h3 { color: #fff; }
.section-navy p { color: #b9c6da; }
.section-head { max-width: 760px; margin: 0 auto 3rem; text-align: center; }
.section-head.text-start { margin-left: 0; text-align: left; }
.lead { font-size: 1.15rem; color: var(--slate); }

/* ---------- Buttons ---------- */
.btn { font-weight: 600; border-radius: 10px; padding: .62rem 1.15rem; letter-spacing: -.01em; transition: all .15s ease; }
.btn-lg { padding: .85rem 1.6rem; font-size: 1.02rem; }
.btn-sm { padding: .4rem .75rem; font-size: .85rem; }
.btn-primary { background: var(--blue); border-color: var(--blue); box-shadow: 0 8px 20px -8px rgba(47,111,237,.7); }
.btn-primary:hover, .btn-primary:focus { background: var(--blue-600); border-color: var(--blue-600); transform: translateY(-1px); }
.btn-outline-primary { color: var(--blue-600); border-color: #c5d6fb; }
.btn-outline-primary:hover { background: var(--blue); border-color: var(--blue); color: #fff; }
.btn-outline-contrast { color: #fff; border: 1px solid rgba(255,255,255,.4); }
.btn-outline-contrast:hover { background: rgba(255,255,255,.12); color: #fff; border-color: #fff; }
.btn-ghost { color: var(--ink); background: var(--bg-soft); border: 1px solid var(--line); }
.btn-ghost:hover { background: var(--bg-soft-2); }

/* ---------- Topbar + Navbar ---------- */
.site-header { position: sticky; top: 0; z-index: 1030; }
.topbar { background: var(--navy); color: #c6d2e4; font-size: .82rem; padding: .4rem 0; }
.topbar a { color: #dbe6f7; }
.topbar a:hover { color: #fff; }
.topbar .sep { display: inline-block; width: 3px; height: 3px; margin: 0 .55rem; border-radius: 50%; background: currentColor; opacity: .45; vertical-align: middle; }
.topbar-links a { font-family: var(--mono); }

.main-nav { background: rgba(255,255,255,.92); backdrop-filter: saturate(160%) blur(10px); border-bottom: 1px solid var(--line); padding: .55rem 0; }
.navbar-brand { display: flex; align-items: center; gap: .6rem; padding: 0; }
.brand-mark { color: var(--blue); flex: none; }
.brand-text { display: flex; flex-direction: column; line-height: 1; }
.brand-name { font-weight: 800; font-size: 1.18rem; letter-spacing: -.02em; color: var(--ink); }
.brand-sub { font: 600 .68rem/1 var(--mono); letter-spacing: .22em; text-transform: uppercase; color: var(--blue-600); margin-top: .18rem; }
.main-nav .nav-link { color: var(--slate); font-weight: 500; padding: .5rem .85rem; border-radius: 8px; }
.main-nav .nav-link:hover { color: var(--ink); background: var(--bg-soft); }
.main-nav .nav-link.active { color: var(--blue-600); font-weight: 600; }
.btn-lang { background: var(--bg-soft); border: 1px solid var(--line); color: var(--ink); display: inline-flex; align-items: center; gap: .35rem; }
.btn-lang:hover { background: var(--bg-soft-2); }
.lang-flag { font-size: 1rem; }
.lang-switcher .dropdown-item.active { background: var(--sky-soft); color: var(--blue-700); }
.lang-switcher .dropdown-item { display: flex; gap: .5rem; align-items: center; }

/* ---------- Hero ---------- */
.hero {
  position: relative; overflow: hidden; color: #fff;
  background: radial-gradient(1100px 500px at 85% -10%, #1b3e74 0%, transparent 55%),
              radial-gradient(900px 500px at 0% 100%, #16294a 0%, transparent 50%),
              linear-gradient(160deg, #0d1b2a 0%, #0c1f3c 100%);
}
.hero::before {
  content: ""; position: absolute; inset: 0;
  background-image: linear-gradient(rgba(255,255,255,.045) 1px, transparent 1px),
                    linear-gradient(90deg, rgba(255,255,255,.045) 1px, transparent 1px);
  background-size: 44px 44px; mask-image: radial-gradient(circle at 60% 30%, #000 0%, transparent 75%);
}
.hero .container { position: relative; z-index: 2; }
.hero { padding: clamp(3.5rem, 8vw, 6.5rem) 0 clamp(3rem, 6vw, 5rem); }
.hero h1 { color: #fff; }
.hero .lead { color: #c3d1e6; font-size: 1.2rem; }
.hero-badges { display: flex; flex-wrap: wrap; gap: .6rem; margin-bottom: 1.4rem; }
.pill {
  display: inline-flex; align-items: center; gap: .45rem;
  background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.16);
  color: #dce6f5; padding: .35rem .8rem; border-radius: 999px; font: 500 .82rem/1 var(--mono);
}
.dot { width: .55rem; height: .55rem; border-radius: 50%; display: inline-block; background: var(--slate-300); }
.dot-live { background: #34d399; box-shadow: 0 0 0 0 rgba(52,211,153,.7); animation: pulse 2s infinite; }
@keyframes pulse { 0% { box-shadow: 0 0 0 0 rgba(52,211,153,.6); } 70% { box-shadow: 0 0 0 7px rgba(52,211,153,0); } 100% { box-shadow: 0 0 0 0 rgba(52,211,153,0); } }
.hero-actions { display: flex; flex-wrap: wrap; gap: .8rem; margin-top: 1.6rem; }
.hero-trust { margin-top: 2rem; color: #93a6c2; font-size: .85rem; font-family: var(--mono); }

/* ---------- Code / terminal card ---------- */
.code-card { background: var(--code-bg); border: 1px solid var(--code-line); border-radius: var(--radius); box-shadow: var(--shadow-lg); overflow: hidden; }
.code-head { display: flex; align-items: center; gap: .5rem; padding: .7rem 1rem; border-bottom: 1px solid var(--code-line); background: #0a1120; }
.code-head .traffic { display: flex; gap: .4rem; }
.code-head .traffic i { width: .72rem; height: .72rem; border-radius: 50%; display: inline-block; }
.tl-red { background: #ff5f57; } .tl-amber { background: #febc2e; } .tl-green { background: #28c840; }
.code-head .code-title { font: 500 .8rem/1 var(--mono); color: #7d8db0; margin-left: .4rem; }
.code-body { margin: 0; padding: 1.1rem 1.25rem; font: .86rem/1.65 var(--mono); color: #cdd9f0; overflow-x: auto; }
.code-body .k { color: #7aa2f7; } .code-body .s { color: #9ece6a; } .code-body .n { color: #ff9e64; } .code-body .c { color: #5c6f93; } .code-body .p { color: #bb9af7; }
pre.code-block { background: var(--code-bg); color: #cdd9f0; border-radius: var(--radius-sm); padding: 1.1rem 1.25rem; font: .85rem/1.6 var(--mono); overflow-x: auto; border: 1px solid var(--code-line); }
code.inline { font-family: var(--mono); background: var(--bg-soft-2); color: var(--blue-700); padding: .12rem .4rem; border-radius: 6px; font-size: .9em; }
.code-copy { position: absolute; top: .6rem; right: .6rem; background: rgba(255,255,255,.08); color: #9fb3d6; border: 1px solid var(--code-line); border-radius: 6px; font: 500 .72rem/1 var(--mono); padding: .3rem .5rem; cursor: pointer; }
.code-copy:hover { background: rgba(255,255,255,.16); color: #fff; }
.section-navy code.inline { background: rgba(255,255,255,.1); color: #cfe0ff; }

/* ---------- Cards / feature grid ---------- */
.feature-card { background: #fff; border: 1px solid var(--line); border-radius: var(--radius); padding: 1.6rem; height: 100%; transition: border-color .15s, transform .15s, box-shadow .15s; }
.feature-card:hover { border-color: #cdd9ef; transform: translateY(-3px); box-shadow: var(--shadow); }
.icon-tile { width: 46px; height: 46px; border-radius: 11px; display: grid; place-items: center; background: var(--sky-soft); color: var(--blue-600); margin-bottom: 1rem; }
.icon-tile svg { width: 24px; height: 24px; }
.feature-card h3 { font-size: 1.12rem; margin-bottom: .4rem; }
.feature-card p { font-size: .96rem; margin: 0; }
.card-soft { background: var(--bg-soft); border: 1px solid var(--line); border-radius: var(--radius); }

/* ---------- Stat strip ---------- */
.stat-strip { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1rem; }
.stat { text-align: center; padding: 1rem; }
.stat .num { font-size: 2.1rem; font-weight: 800; color: var(--ink); letter-spacing: -.03em; }
.section-navy .stat .num { color: #fff; }
.stat .lbl { font: 500 .82rem/1.3 var(--mono); color: var(--slate-2); text-transform: uppercase; letter-spacing: .06em; }
.section-navy .stat .lbl { color: #93a6c2; }

/* ---------- Logos / list checks ---------- */
.check-list { list-style: none; padding: 0; margin: 0; }
.check-list li { position: relative; padding-left: 1.9rem; margin-bottom: .7rem; color: var(--slate); }
.check-list li::before { content: ""; position: absolute; left: 0; top: .15rem; width: 1.25rem; height: 1.25rem; border-radius: 50%; background: var(--sky-soft) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%231d4ed8' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E") center/0.8rem no-repeat; }

/* ---------- Tables ---------- */
.table-compare, .table-pricing { width: 100%; border-collapse: separate; border-spacing: 0; border: 1px solid var(--line); border-radius: var(--radius); overflow: hidden; background: #fff; }
.table-compare th, .table-compare td, .table-pricing th, .table-pricing td { padding: .95rem 1.1rem; border-bottom: 1px solid var(--line); text-align: left; vertical-align: top; }
.table-compare thead th, .table-pricing thead th { background: var(--bg-soft); font-size: .92rem; color: var(--ink); }
.table-compare tbody tr:last-child td, .table-pricing tbody tr:last-child td { border-bottom: 0; }
.table-compare td .yes { color: var(--green); font-weight: 700; }
.table-compare td .no { color: var(--slate-300); }
.badge-soft { display: inline-block; background: var(--sky-soft); color: var(--blue-700); font: 600 .72rem/1 var(--mono); padding: .3rem .55rem; border-radius: 6px; letter-spacing: .04em; }
.badge-amber { background: #fef3c7; color: var(--amber); }
.badge-green { background: #dcfce7; color: var(--green); }

/* ---------- Inventory items ---------- */
.inv-card { display: flex; flex-direction: column; background: #fff; border: 1px solid var(--line); border-radius: var(--radius); overflow: hidden; height: 100%; transition: transform .15s, box-shadow .15s; }
.inv-card:hover { transform: translateY(-3px); box-shadow: var(--shadow); }
.inv-media { aspect-ratio: 16/10; background: var(--bg-soft-2) center/cover; position: relative; }
.inv-media .tag { position: absolute; top: .7rem; left: .7rem; }
.inv-body { padding: 1.1rem 1.2rem; display: flex; flex-direction: column; gap: .4rem; flex: 1; }
.inv-body h3 { font-size: 1.05rem; }
.inv-meta { display: flex; justify-content: space-between; align-items: center; margin-top: auto; padding-top: .6rem; border-top: 1px dashed var(--line); font: 500 .85rem/1 var(--mono); color: var(--slate-2); }
.inv-price { color: var(--blue-700); font-weight: 700; }

/* ---------- Pricing tiers ---------- */
.price-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.25rem; }
.price-card { background: #fff; border: 1px solid var(--line); border-radius: var(--radius); padding: 1.8rem 1.5rem; position: relative; height: 100%; }
.price-card.featured { border-color: var(--blue); box-shadow: var(--shadow); }
.price-card.featured::before { content: attr(data-badge); position: absolute; top: -.8rem; left: 1.5rem; background: var(--blue); color: #fff; font: 600 .72rem/1 var(--mono); padding: .35rem .65rem; border-radius: 6px; letter-spacing: .04em; }
.price-card h3 { font-size: 1.2rem; }
.price-card .price { font-size: 2.2rem; font-weight: 800; letter-spacing: -.03em; margin: .3rem 0; }
.price-card .price small { font-size: .95rem; font-weight: 500; color: var(--slate-2); }

/* ---------- Accordion / FAQ ---------- */
.accordion-item { border: 1px solid var(--line); border-radius: var(--radius-sm) !important; margin-bottom: .7rem; overflow: hidden; }
.accordion-button { font-weight: 600; color: var(--ink); }
.accordion-button:not(.collapsed) { color: var(--blue-700); background: var(--bg-soft); box-shadow: none; }
.accordion-button:focus { box-shadow: 0 0 0 .2rem rgba(47,111,237,.18); }

/* ---------- Breadcrumbs ---------- */
.breadcrumbs { background: var(--bg-soft); border-bottom: 1px solid var(--line); padding: .7rem 0; }
.breadcrumbs .breadcrumb { font-size: .88rem; }
.breadcrumbs .breadcrumb-item a { color: var(--slate-2); }
.breadcrumbs .breadcrumb-item.active { color: var(--ink); }

/* ---------- Page header ---------- */
.page-hero { background: var(--navy); color: #fff; padding: clamp(2.6rem,5vw,4rem) 0; position: relative; overflow: hidden; }
.page-hero::before { content:""; position:absolute; inset:0; background-image: linear-gradient(90deg, rgba(255,255,255,.04) 1px, transparent 1px); background-size: 40px 40px; opacity:.6; }
.page-hero .container { position: relative; z-index: 2; }
.page-hero h1 { color: #fff; }
.page-hero p { color: #b9c6da; max-width: 720px; }

/* ---------- Blog ---------- */
.blog-card { background: #fff; border: 1px solid var(--line); border-radius: var(--radius); overflow: hidden; height: 100%; display: flex; flex-direction: column; transition: transform .15s, box-shadow .15s; }
.blog-card:hover { transform: translateY(-3px); box-shadow: var(--shadow); }
.blog-media { aspect-ratio: 16/9; background: var(--bg-soft-2) center/cover; }
.blog-card .body { padding: 1.2rem 1.3rem; display: flex; flex-direction: column; flex: 1; }
.blog-card h3 { font-size: 1.14rem; margin: .3rem 0 .5rem; }
.blog-card .meta { font: 500 .8rem/1 var(--mono); color: var(--slate-2); display: flex; gap: .6rem; align-items: center; }
.blog-card .excerpt { color: var(--slate); font-size: .96rem; flex: 1; }
.tag-chip { font: 600 .72rem/1 var(--mono); color: var(--blue-700); background: var(--sky-soft); padding: .28rem .55rem; border-radius: 6px; }
.article { font-size: 1.08rem; }
.article h2 { margin: 2.2rem 0 .9rem; }
.article h3 { margin: 1.7rem 0 .7rem; }
.article p, .article li { color: #334155; }
.article ul, .article ol { padding-left: 1.3rem; }
.article li { margin-bottom: .45rem; }
.article blockquote { border-left: 4px solid var(--blue); background: var(--bg-soft); padding: 1rem 1.3rem; border-radius: 0 8px 8px 0; color: var(--ink); font-size: 1.05rem; margin: 1.6rem 0; }
.article pre.code-block { margin: 1.4rem 0; }
.article-meta { display: flex; flex-wrap: wrap; gap: .8rem; align-items: center; color: var(--slate-2); font: 500 .86rem/1 var(--mono); }

/* ---------- Sidebar ---------- */
.sidebar { display: flex; flex-direction: column; gap: 1.2rem; position: sticky; top: 90px; }
.sidebar-card { background: #fff; border: 1px solid var(--line); border-radius: var(--radius); padding: 1.3rem; }
.sidebar-h { font-size: 1rem; font-weight: 700; margin-bottom: .9rem; }
.sidebar-posts { list-style: none; padding: 0; margin: 0; }
.sidebar-posts li { padding: .6rem 0; border-bottom: 1px solid var(--line-2); }
.sidebar-posts li:last-child { border-bottom: 0; }
.sidebar-posts a { font-weight: 600; color: var(--ink); font-size: .96rem; display: block; }
.sidebar-posts a:hover { color: var(--blue-600); }
.sidebar-posts time { font: 500 .76rem/1 var(--mono); color: var(--slate-2); }
.sidebar-toc { list-style: none; padding: 0; margin: 0; }
.sidebar-toc li { margin-bottom: .5rem; }
.sidebar-toc a { color: var(--slate); font-size: .95rem; }
.sidebar-cta { background: var(--navy); color: #fff; }
.sidebar-cta .sidebar-h, .sidebar-cta p { color: #fff; }
.sidebar-cta p { color: #b9c6da; font-size: .92rem; }
.sidebar-cta .btn-link { color: #cfe0ff; }

/* ---------- Forms ---------- */
.form-card { background: #fff; border: 1px solid var(--line); border-radius: var(--radius); padding: 1.8rem; box-shadow: var(--shadow-sm); }
.form-label { font-weight: 600; font-size: .9rem; color: var(--ink); }
.form-control, .form-select { border-color: var(--line); padding: .7rem .85rem; border-radius: 10px; }
.form-control:focus, .form-select:focus { border-color: var(--blue); box-shadow: 0 0 0 .2rem rgba(47,111,237,.15); }
.hp-field { position: absolute; left: -9999px; opacity: 0; height: 0; width: 0; }
.form-note { font-size: .85rem; color: var(--slate-2); }
.form-status { display: none; border-radius: 10px; padding: .85rem 1rem; margin-bottom: 1rem; font-weight: 500; }
.form-status.show { display: block; }
.form-status.ok { background: #dcfce7; color: #166534; }
.form-status.err { background: #fee2e2; color: #991b1b; }

/* ---------- Contact info blocks ---------- */
.info-row { display: flex; gap: .9rem; align-items: flex-start; padding: 1rem 0; border-bottom: 1px solid var(--line-2); }
.info-row:last-child { border-bottom: 0; }
.info-row .icon-tile { margin: 0; flex: none; width: 42px; height: 42px; }
.info-row a { color: var(--ink); font-weight: 600; }
.map-embed { border: 1px solid var(--line); border-radius: var(--radius); overflow: hidden; }
.map-embed iframe { display: block; width: 100%; height: 320px; border: 0; }

/* ---------- CTA band ---------- */
.cta-band { background: linear-gradient(120deg, var(--blue-700), var(--blue) 55%, #3f86ff); color: #fff; padding: clamp(2.4rem, 5vw, 3.4rem) 0; }
.cta-inner { display: flex; align-items: center; justify-content: space-between; gap: 1.5rem; flex-wrap: wrap; }
.cta-title { color: #fff; margin: 0 0 .3rem; }
.cta-text { color: rgba(255,255,255,.88); margin: 0; max-width: 620px; }
.cta-actions { display: flex; gap: .7rem; flex-wrap: wrap; }

/* ---------- Footer ---------- */
.site-footer { background: var(--navy); color: #aebbd0; padding: 3.5rem 0 1.6rem; }
.footer-top { padding-bottom: 2.2rem; border-bottom: 1px solid rgba(255,255,255,.08); }
.footer-brand { display: inline-flex; align-items: center; gap: .55rem; color: #fff; margin-bottom: 1rem; }
.footer-brand:hover { text-decoration: none; }
.footer-brand .brand-mark { color: var(--sky); }
.footer-brand .brand-name { color: #fff; }
.footer-tagline { color: #aebbd0; max-width: 340px; }
.footer-license { margin: 1rem 0; }
.badge-tursab { display: inline-block; border: 1px solid rgba(255,255,255,.2); color: #cfe0ff; font: 600 .76rem/1 var(--mono); padding: .4rem .65rem; border-radius: 8px; }
.footer-social { display: flex; gap: .6rem; margin-top: 1rem; }
.footer-social a { width: 38px; height: 38px; display: grid; place-items: center; border-radius: 9px; background: rgba(255,255,255,.06); color: #cdd9ef; transition: background .15s, color .15s; }
.footer-social a:hover { background: var(--blue); color: #fff; }
.footer-h { font-size: .82rem; text-transform: uppercase; letter-spacing: .1em; color: #fff; margin-bottom: 1rem; font-family: var(--mono); }
.footer-links { list-style: none; padding: 0; margin: 0; }
.footer-links li { margin-bottom: .6rem; }
.footer-links a { color: #aebbd0; }
.footer-links a:hover { color: #fff; text-decoration: none; }
.footer-contact p { color: #aebbd0; margin-bottom: .7rem; font-style: normal; }
.footer-contact a { color: #cdd9ef; }
.footer-support { display: flex; align-items: center; gap: .5rem; }
.footer-bottom { display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: .8rem; padding-top: 1.4rem; font-size: .85rem; }
.footer-legal { list-style: none; display: flex; gap: 1.2rem; padding: 0; margin: 0; }
.footer-legal a { color: #aebbd0; }

/* ---------- Images inside media containers ---------- */
.inv-media img, .blog-media img { width: 100%; height: 100%; object-fit: cover; display: block; }
.ratio > img { object-fit: cover; }

/* ---------- CSS-drawn arrows / separators (no glyph characters) ---------- */
.btn-arrow::after, .link-arrow::after {
  content: ""; display: inline-block; width: .42em; height: .42em;
  border-top: 2px solid currentColor; border-right: 2px solid currentColor;
  transform: rotate(45deg); margin-left: .5em; vertical-align: middle;
}
.btn-arrow-back::before {
  content: ""; display: inline-block; width: .42em; height: .42em;
  border-top: 2px solid currentColor; border-right: 2px solid currentColor;
  transform: rotate(-135deg); margin-right: .5em; vertical-align: middle;
}
.link-arrow { font-weight: 600; }
.meta-sep { display: inline-block; width: 3px; height: 3px; border-radius: 50%; background: currentColor; opacity: .5; vertical-align: middle; }

/* ---------- Misc ---------- */
.divider-dashed { border-top: 1px dashed var(--line); }
.text-mono { font-family: var(--mono); }
.bg-grid-soft { background-image: linear-gradient(var(--line-2) 1px, transparent 1px), linear-gradient(90deg, var(--line-2) 1px, transparent 1px); background-size: 32px 32px; }

/* ---------- Responsive ---------- */
@media (max-width: 991px) {
  .stat-strip { grid-template-columns: repeat(2, 1fr); }
  .price-grid { grid-template-columns: 1fr; }
  .main-nav { background: #fff; }
  .header-actions { margin-top: .6rem; }
  .sidebar { position: static; }
  .cta-inner { flex-direction: column; align-items: flex-start; }
}
@media (max-width: 575px) {
  .stat-strip { grid-template-columns: 1fr 1fr; }
  .footer-bottom { flex-direction: column; align-items: flex-start; }
}
