/* ═══════════════════════════════════════════════════════════════════════════
   Kirapp eSIM — Main Stylesheet
   Brand Guide v2.0 · Inter + JetBrains Mono · kirOrange + kirTeal + kirDark
   ═══════════════════════════════════════════════════════════════════════════ */

/* ── Design Tokens ─────────────────────────────────────────────────────────── */
:root {
  --ko:      #FD7232;   /* kirOrange  — CTAs, prices, accent       */
  --ko-lt:   #FFB96E;   /* kirOrange light                          */
  --ko-dk:   #E86824;   /* kirOrange dark                           */
  --kt:      #5DC3C7;   /* kirTeal    — links, success, labels      */
  --kt-dk:   #2EB1B4;   /* kirTeal dark                             */
  --kd:      #333645;   /* kirDark    — text, dark backgrounds      */
  --kd2:     #696F8A;   /* kirDark2   — gradients                   */
  --kg:      #969696;   /* kirGray    — secondary text              */
  --kg-dk:   #6F6F6F;   /* kirGrayDark — tertiary text              */
  --kwg:     #EFEFEF;   /* kirWhiteGray — soft backgrounds          */

  --grad-orange: linear-gradient(135deg, #FFB96E, #FC3F07);
  --grad-teal:   linear-gradient(135deg, #60C4C8, #2EB1B4);
  --grad-dark:   linear-gradient(135deg, #696F8A, #333645);
  --grad-red:    linear-gradient(135deg, #F3945E, #D43434);

  /* Spacing */
  --sp-xs:  4px;
  --sp-sm:  8px;
  --sp-md:  16px;
  --sp-lg:  24px;
  --sp-xl:  32px;
  --sp-xxl: 48px;

  /* Radius */
  --r-sm:   6px;
  --r-md:   12px;
  --r-lg:   16px;
  --r-xl:   24px;
  --r-pill: 100px;

  /* Typography */
  --font:      'Inter', sans-serif;
  --font-mono: 'JetBrains Mono', monospace;
}

/* ── Reset ──────────────────────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { font-size: 16px; scroll-behavior: smooth; }
body {
  font-family: var(--font);
  color: var(--kd);
  background: #ffffff;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
}
img { max-width: 100%; display: block; }
a { text-decoration: none; color: inherit; }
button { font-family: var(--font); cursor: pointer; }

/* ── Layout ─────────────────────────────────────────────────────────────────── */
.kir-body { display: flex; flex-direction: column; min-height: 100vh; }
.kir-main { flex: 1; }
.kir-container { max-width: 1200px; margin: 0 auto; padding: 0 var(--sp-lg); }

/* ── Navigation ─────────────────────────────────────────────────────────────── */
.kir-nav {
  background: var(--kd);
  position: sticky; top: 0; z-index: 100;
  box-shadow: 0 1px 0 rgba(255,255,255,.06);
}
.kir-nav-inner {
  max-width: 1200px; margin: 0 auto;
  display: flex; align-items: center;
  justify-content: space-between;
  padding: 0 var(--sp-lg);
  height: 60px;
  position: relative;
}
.kir-logo-link { display: flex; align-items: center; gap: var(--sp-sm); }
.kir-logo-icon {
  width: 32px; height: 32px;
  background: var(--ko); border-radius: 8px;
  display: flex; align-items: center; justify-content: center;
  font-weight: 800; font-size: 16px; color: #fff;
  flex-shrink: 0;
}
.kir-logo-text {
  font-weight: 700; font-size: 16px; color: #fff;
  letter-spacing: -0.02em;
}
.kir-logo-text em { color: var(--ko); font-style: normal; }

.kir-nav-links {
  display: flex; gap: var(--sp-xl); list-style: none;
}
.kir-nav-links a {
  color: rgba(255,255,255,.65); font-size: 13px; font-weight: 500;
  transition: color .15s; padding: 4px 0;
}
.kir-nav-links a:hover,
.kir-nav-links a.active { color: #fff; }

.kir-nav-right {
  display: flex; align-items: center; gap: var(--sp-md);
}
.kir-lang-switch { display: flex; align-items: center; gap: 5px; }
.kir-lang-switch a {
  font-size: 11px; font-weight: 600; color: rgba(255,255,255,.4);
  letter-spacing: .05em; transition: color .15s;
}
.kir-lang-switch a:hover,
.kir-lang-switch a.active { color: rgba(255,255,255,.85); }
.kir-lang-switch span { color: rgba(255,255,255,.2); font-size: 10px; }

.kir-btn-ghost {
  background: transparent;
  border: 1px solid rgba(255,255,255,.22);
  color: #fff; font-size: 12px; font-weight: 600;
  padding: 6px 14px; border-radius: var(--r-pill);
  transition: border-color .15s, opacity .15s;
}
.kir-btn-ghost:hover { border-color: rgba(255,255,255,.5); }

.kir-btn-primary {
  background: var(--ko); border: none;
  color: #fff; font-size: 12px; font-weight: 600;
  padding: 7px 16px; border-radius: var(--r-pill);
  transition: opacity .15s;
}
.kir-btn-primary:hover { opacity: .9; }

.kir-user-btn {
  display: flex; align-items: center; gap: 7px;
}
.kir-user-avatar {
  width: 30px; height: 30px; border-radius: 50%;
  background: var(--ko); color: #fff;
  display: flex; align-items: center; justify-content: center;
  font-size: 13px; font-weight: 700;
}
.kir-user-name { font-size: 13px; color: rgba(255,255,255,.8); font-weight: 500; }

/* Hamburger */
.kir-ham {
  display: none; flex-direction: column; gap: 5px;
  background: none; border: none; padding: 4px; z-index: 20;
}
.kir-ham span {
  display: block; width: 22px; height: 2px;
  background: rgba(255,255,255,.75); border-radius: 2px;
  transition: all .2s;
}
.kir-ham.open span:nth-child(1) { transform: rotate(45deg) translate(5px,5px); }
.kir-ham.open span:nth-child(2) { opacity: 0; }
.kir-ham.open span:nth-child(3) { transform: rotate(-45deg) translate(5px,-5px); }

/* Mobile drawer */
.kir-drawer {
  display: none; flex-direction: column;
  background: var(--kd);
  border-top: .5px solid rgba(255,255,255,.1);
  padding: var(--sp-md) var(--sp-lg) var(--sp-lg);
}
.kir-drawer.open { display: flex; }
.kir-drawer a {
  color: rgba(255,255,255,.7); font-size: 14px; font-weight: 500;
  padding: 11px 0; border-bottom: .5px solid rgba(255,255,255,.07);
}
.kir-drawer a:hover { color: #fff; }
.kir-drawer-divider { height: .5px; background: rgba(255,255,255,.1); margin: var(--sp-sm) 0; }
.kir-drawer-cta {
  background: var(--ko) !important; color: #fff !important;
  border-radius: var(--r-pill); text-align: center;
  padding: 10px !important; margin-top: var(--sp-sm) !important;
  border-bottom: none !important; font-weight: 700 !important;
}
.kir-drawer-lang { margin-top: var(--sp-md); font-size: 12px; color: rgba(255,255,255,.4); }
.kir-drawer-lang a { color: rgba(255,255,255,.5); border-bottom: none !important; padding: 0 !important; }

/* ── Hero ────────────────────────────────────────────────────────────────────── */
.kir-hero {
  background: var(--grad-dark);
  padding: var(--sp-xxl) var(--sp-lg) 0;
  text-align: center;
  position: relative; overflow: hidden;
}
.kir-hero::before {
  content: ''; position: absolute; top: -80px; right: -80px;
  width: 320px; height: 320px; border-radius: 50%;
  background: var(--ko); opacity: .07;
}
.kir-eyebrow {
  display: inline-flex; align-items: center; gap: 6px;
  background: rgba(93,195,199,.12);
  border: 1px solid rgba(93,195,199,.28);
  border-radius: var(--r-pill); padding: 4px 14px;
  margin-bottom: var(--sp-md);
}
.kir-eyebrow-dot { width: 5px; height: 5px; background: var(--kt); border-radius: 50%; }
.kir-eyebrow span { font-size: 10px; font-weight: 600; color: var(--kt); letter-spacing: .06em; }

.kir-hero-h1 {
  font-size: clamp(28px, 5vw, 44px); font-weight: 800;
  color: #fff; line-height: 1.05; letter-spacing: -.04em;
  margin-bottom: var(--sp-md);
}
.kir-hero-h1 em { color: var(--ko); font-style: normal; }

.kir-hero-sub {
  font-size: clamp(13px, 2vw, 15px); color: rgba(255,255,255,.58);
  margin-bottom: var(--sp-xl); line-height: 1.6;
}

/* ── Search Card ─────────────────────────────────────────────────────────────── */
.kir-search-card {
  background: #fff; border-radius: 20px 20px 0 0;
  padding: clamp(18px, 4vw, 28px);
  box-shadow: 0 -8px 40px rgba(0,0,0,.15);
  text-align: left; position: relative; z-index: 2;
  max-width: 720px; margin: 0 auto;
}
.kir-search-label {
  font-size: 10px; font-weight: 700; color: var(--kg);
  letter-spacing: .07em; margin-bottom: var(--sp-sm);
}
.kir-search-row { display: flex; gap: var(--sp-sm); align-items: stretch; }
.kir-search-wrap { flex: 1; position: relative; }
.kir-search-inp {
  width: 100%; padding: 13px 13px 13px 42px;
  border: 1.5px solid #e5e5e5; border-radius: 12px;
  font-family: var(--font); font-size: 14px; font-weight: 500;
  color: var(--kd); outline: none; transition: border-color .15s;
}
.kir-search-inp:focus { border-color: var(--ko); }
.kir-search-ico {
  position: absolute; left: 13px; top: 50%; transform: translateY(-50%);
  color: var(--kg); font-size: 15px; pointer-events: none;
}
.kir-search-btn {
  background: var(--ko); border: none; color: #fff;
  font-size: 13px; font-weight: 700; padding: 0 22px;
  border-radius: 12px; white-space: nowrap; transition: opacity .15s;
}
.kir-search-btn:hover { opacity: .9; }

.kir-tags { margin-top: 10px; display: flex; align-items: center; gap: 6px; flex-wrap: wrap; }
.kir-tags-lbl { font-size: 10px; color: var(--kg); font-weight: 500; }
.kir-tag {
  background: var(--kwg); border-radius: var(--r-pill);
  padding: 4px 10px; font-size: 11px; font-weight: 600;
  color: var(--kd); border: none; transition: background .15s;
}
.kir-tag:hover { background: #e0e0e0; }

/* ── Trust strip ─────────────────────────────────────────────────────────────── */
.kir-trust {
  background: #f9f9f9; border-bottom: .5px solid #ebebeb;
  display: flex; justify-content: center;
  gap: clamp(16px, 4vw, 40px); padding: 14px var(--sp-lg);
  flex-wrap: wrap;
}
.kir-trust-item { display: flex; align-items: center; gap: 6px; font-size: 12px; font-weight: 500; color: #666; }
.kir-trust-icon {
  width: 18px; height: 18px; background: rgba(93,195,199,.12);
  border-radius: 50%; display: flex; align-items: center; justify-content: center;
  font-size: 10px; flex-shrink: 0;
}

/* ── Section headings ────────────────────────────────────────────────────────── */
.kir-section { padding: clamp(28px, 5vw, 48px) var(--sp-lg); }
.kir-section-h {
  font-size: clamp(18px, 3vw, 24px); font-weight: 700;
  color: var(--kd); letter-spacing: -.02em; margin-bottom: 4px;
}
.kir-section-s { font-size: 13px; color: var(--kg); margin-bottom: var(--sp-lg); }

/* ── Steps ───────────────────────────────────────────────────────────────────── */
.kir-steps { display: grid; grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)); gap: 12px; }
.kir-step { background: #f7f7f7; border-radius: var(--r-md); padding: var(--sp-md); border: .5px solid #ebebeb; }
.kir-step-num {
  width: 28px; height: 28px; background: var(--ko); border-radius: 8px;
  display: flex; align-items: center; justify-content: center;
  font-size: 13px; font-weight: 800; color: #fff; margin-bottom: 10px;
}
.kir-step-t { font-size: 13px; font-weight: 700; color: var(--kd); margin-bottom: 4px; }
.kir-step-d { font-size: 12px; color: var(--kg); line-height: 1.5; }

/* ── Plan grid ───────────────────────────────────────────────────────────────── */
.kir-plan-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(155px, 1fr)); gap: 10px; }
.kir-plan-card {
  background: #fff; border: .5px solid #e8e8e8; border-radius: var(--r-md);
  padding: 14px; cursor: pointer; transition: border-color .15s, transform .1s;
}
.kir-plan-card:hover { border-color: var(--ko); transform: translateY(-2px); }
.kir-plan-flag { width: 32px; height: 23px; border-radius: 4px; object-fit: cover; margin-bottom: 8px; }
.kir-plan-name { font-size: 12px; font-weight: 700; color: var(--kd); margin-bottom: 1px; }
.kir-plan-region { font-size: 10px; color: var(--kg); margin-bottom: 8px; }
.kir-plan-data { font-size: 18px; font-weight: 800; color: var(--ko); letter-spacing: -.03em; line-height: 1; }
.kir-plan-data span { font-size: 11px; font-weight: 500; color: var(--kg); }
.kir-plan-price { font-size: 12px; font-weight: 600; color: var(--kd); margin-top: 3px; }

/* ── Blog cards ──────────────────────────────────────────────────────────────── */
.kir-blog-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); gap: 14px; margin-top: var(--sp-md); }
.kir-blog-card { background: #fff; border-radius: var(--r-md); overflow: hidden; border: .5px solid #e8e8e8; cursor: pointer; transition: transform .15s, box-shadow .15s; }
.kir-blog-card:hover { transform: translateY(-2px); box-shadow: 0 8px 24px rgba(0,0,0,.08); }
.kir-blog-img { height: 140px; overflow: hidden; }
.kir-blog-img img { width: 100%; height: 100%; object-fit: cover; }
.kir-blog-img-placeholder { width: 100%; height: 100%; display: flex; align-items: center; justify-content: center; font-size: 32px; }
.kir-blog-body { padding: 12px; }
.kir-blog-cat { font-size: 10px; font-weight: 700; color: var(--kt); letter-spacing: .06em; margin-bottom: 4px; }
.kir-blog-title { font-size: 13px; font-weight: 700; color: var(--kd); line-height: 1.35; margin-bottom: 6px; }
.kir-blog-date { font-size: 11px; color: var(--kg); }

/* ── App download banner ─────────────────────────────────────────────────────── */
.kir-app-banner {
  background: var(--ko); padding: clamp(20px, 4vw, 32px) var(--sp-lg);
  display: flex; align-items: center; justify-content: space-between;
  gap: var(--sp-lg); flex-wrap: wrap;
}
.kir-app-txt h3 { font-size: clamp(15px, 2.5vw, 20px); font-weight: 700; color: #fff; margin-bottom: 4px; }
.kir-app-txt p { font-size: 13px; color: rgba(255,255,255,.75); }
.kir-app-btns { display: flex; gap: 8px; flex-wrap: wrap; flex-shrink: 0; }
.kir-store-btn {
  background: rgba(255,255,255,.15); border: 1px solid rgba(255,255,255,.3);
  color: #fff; font-size: 12px; font-weight: 600;
  padding: 9px 16px; border-radius: 8px; transition: background .15s;
}
.kir-store-btn:hover { background: rgba(255,255,255,.25); }

/* ── Footer ──────────────────────────────────────────────────────────────────── */
.kir-footer { background: var(--kd); }
.kir-footer-inner { max-width: 1200px; margin: 0 auto; padding: clamp(24px, 4vw, 40px) var(--sp-lg) var(--sp-lg); }
.kir-footer-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(140px, 1fr)); gap: var(--sp-xl); margin-bottom: var(--sp-xl); }
.kir-footer-logo { font-weight: 800; font-size: 16px; color: #fff; letter-spacing: -.02em; margin-bottom: 4px; }
.kir-footer-logo em { color: var(--ko); font-style: normal; }
.kir-footer-tagline { font-size: 11px; color: rgba(255,255,255,.35); margin-bottom: var(--sp-md); }
.kir-footer-socials { display: flex; gap: 7px; flex-wrap: wrap; }
.kir-soc-btn {
  width: 28px; height: 28px; background: rgba(255,255,255,.09);
  border-radius: 7px; display: flex; align-items: center; justify-content: center;
  font-size: 10px; font-weight: 700; color: rgba(255,255,255,.5);
  transition: background .15s; text-decoration: none;
}
.kir-soc-btn:hover { background: rgba(255,255,255,.18); color: #fff; }
.kir-footer-col h4 { font-size: 10px; font-weight: 600; color: rgba(255,255,255,.4); letter-spacing: .06em; margin-bottom: 12px; }
.kir-footer-col a { display: block; font-size: 12px; color: rgba(255,255,255,.45); margin-bottom: 8px; transition: color .15s; }
.kir-footer-col a:hover { color: rgba(255,255,255,.8); }
.kir-footer-bottom {
  border-top: .5px solid rgba(255,255,255,.09); padding-top: var(--sp-md);
  display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 8px;
}
.kir-footer-bottom span { font-size: 11px; color: rgba(255,255,255,.28); }
.kir-footer-stores { display: flex; gap: var(--sp-md); }
.kir-store-link { font-size: 11px; color: rgba(255,255,255,.35); transition: color .15s; }
.kir-store-link:hover { color: rgba(255,255,255,.7); }

/* ── Section row header ──────────────────────────────────────────────────────── */
.kir-row-hdr { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: var(--sp-md); }
.kir-see-all { font-size: 12px; font-weight: 600; color: var(--ko); border: none; background: none; cursor: pointer; }

/* ── Monospace (ICCID, LPA codes) ────────────────────────────────────────────── */
.kir-mono { font-family: var(--font-mono); font-size: 12px; }

/* ── Forms ───────────────────────────────────────────────────────────────────── */
.kir-form-group { margin-bottom: var(--sp-md); }
.kir-label { font-size: 11px; font-weight: 600; color: var(--kg); letter-spacing: .04em; margin-bottom: 5px; display: block; }
.kir-input {
  width: 100%; padding: 11px 14px;
  border: 1.5px solid #e5e5e5; border-radius: 10px;
  font-family: var(--font); font-size: 14px; color: var(--kd);
  outline: none; background: #fff; transition: border-color .15s;
}
.kir-input:focus { border-color: var(--ko); }
.kir-input.error { border-color: #e74c3c; }

/* ── Alert messages ──────────────────────────────────────────────────────────── */
.kir-alert { border-radius: 8px; padding: 10px 14px; font-size: 13px; font-weight: 500; margin-bottom: var(--sp-md); display: none; }
.kir-alert.show { display: block; }
.kir-alert.error  { background: rgba(231,76,60,.08); border: .5px solid rgba(231,76,60,.25); color: #c0392b; }
.kir-alert.success{ background: rgba(93,195,199,.08); border: .5px solid rgba(93,195,199,.25); color: var(--kt); }
.kir-alert.info   { background: rgba(253,114,50,.07); border: .5px solid rgba(253,114,50,.25); color: var(--ko); }

/* ── CTA button ──────────────────────────────────────────────────────────────── */
.kir-cta {
  width: 100%; background: var(--ko); border: none; color: #fff;
  font-family: var(--font); font-size: 15px; font-weight: 700;
  padding: 14px; border-radius: 12px; cursor: pointer;
  transition: opacity .15s; letter-spacing: .02em;
}
.kir-cta:hover { opacity: .9; }
.kir-cta:disabled { opacity: .5; cursor: not-allowed; }
.kir-cta.teal { background: var(--kt); }
.kir-cta.ghost { background: transparent; color: var(--kd); border: 1px solid #ddd; }

/* ── Section background variants ─────────────────────────────────────────────── */
.kir-bg-light { background: #f7f8f9; }
.kir-bg-dark  { background: var(--kd); }

/* ══════════════════════════════════════════════════════════════════════════════
   RESPONSIVE BREAKPOINTS
   ══════════════════════════════════════════════════════════════════════════════ */

@media (max-width: 768px) {
  .kir-nav-links,
  .kir-nav-right { display: none !important; }
  .kir-ham { display: flex !important; }
  .kir-plan-grid { grid-template-columns: repeat(2, 1fr); }
  .kir-blog-grid  { grid-template-columns: 1fr; }
  .kir-footer-grid { grid-template-columns: 1fr 1fr; }
  .kir-trust { gap: var(--sp-sm); }
}

@media (max-width: 480px) {
  .kir-search-row { flex-direction: column; }
  .kir-search-btn { padding: 12px; border-radius: 10px; }
  .kir-plan-grid { grid-template-columns: repeat(2, 1fr); gap: 8px; }
  .kir-steps { grid-template-columns: 1fr; }
  .kir-app-banner { flex-direction: column; }
  .kir-footer-grid { grid-template-columns: 1fr; }
}

/* ═══════════════════════════════════════════════════════════════════════════
   Homepage styles
   ═══════════════════════════════════════════════════════════════════════════ */

/* ── Hero ─────────────────────────────────────────────────────────────────── */
.kir-hero {
  background: linear-gradient(135deg, var(--kd) 0%, var(--kd2) 100%);
  padding: var(--sp-xxl) var(--sp-lg) var(--sp-xl);
  text-align: center; position: relative; overflow: hidden;
}
.kir-hero::before {
  content: ''; position: absolute; width: 420px; height: 420px;
  border-radius: 50%; background: rgba(93,195,199,.07);
  top: -100px; right: -80px; pointer-events: none;
}
.kir-hero::after {
  content: ''; position: absolute; width: 300px; height: 300px;
  border-radius: 50%; background: rgba(253,114,50,.06);
  bottom: -80px; left: -60px; pointer-events: none;
}
.kir-hero-title {
  font-size: clamp(28px,5vw,52px); font-weight: 800; color: #fff;
  letter-spacing: -.04em; line-height: 1.07; margin-bottom: 14px;
}
.kir-hero-accent { color: var(--ko); font-style: normal; }
.kir-hero-sub {
  font-size: clamp(13px,2vw,16px); color: rgba(255,255,255,.6);
  line-height: 1.7; max-width: 540px; margin: 0 auto var(--sp-xl);
}
.kir-hero-search {
  display: flex; gap: 8px; max-width: 540px; margin: 0 auto var(--sp-lg);
}
.kir-hero-search-inp {
  flex: 1; padding: 13px 16px; border: none; border-radius: 12px;
  font-family: var(--font); font-size: 14px; color: var(--kd); outline: none;
}
.kir-hero-search-btn {
  background: var(--ko); border: none; color: #fff;
  font-family: var(--font); font-size: 13px; font-weight: 700;
  padding: 0 22px; border-radius: 12px; cursor: pointer; white-space: nowrap;
}
.kir-hero-trust {
  display: flex; justify-content: center; gap: 18px; flex-wrap: wrap;
}
.kir-trust-item { font-size: 11px; color: rgba(255,255,255,.5); font-weight: 500; }

/* ── Stats strip ──────────────────────────────────────────────────────────── */
.kir-stats-strip {
  background: var(--color-background-primary);
  border-bottom: .5px solid var(--color-border-tertiary);
}
.kir-stats-grid {
  display: grid; grid-template-columns: repeat(4,1fr);
  max-width: 900px; margin: 0 auto;
}
.kir-stat-item {
  padding: 18px 16px; text-align: center;
  border-right: .5px solid var(--color-border-tertiary);
}
.kir-stat-item:last-child { border-right: none; }
.kir-stat-num {
  font-size: clamp(22px,3vw,32px); font-weight: 800; color: var(--ko);
  letter-spacing: -.03em; margin-bottom: 3px;
}
.kir-stat-lbl { font-size: 10px; font-weight: 700; color: var(--kg); letter-spacing: .05em; }

/* ── Section helpers ──────────────────────────────────────────────────────── */
.kir-section { padding: var(--sp-xxl) var(--sp-lg); }
.kir-section-white { background: var(--color-background-primary); }
.kir-section-soft  { background: var(--color-background-secondary); }
.kir-section-header { margin-bottom: var(--sp-xl); }
.kir-section-header--row {
  display: flex; justify-content: space-between; align-items: flex-end;
  flex-wrap: wrap; gap: 12px;
}
.kir-section-title {
  font-size: clamp(20px,3.5vw,30px); font-weight: 800; color: var(--kd);
  letter-spacing: -.03em; margin-bottom: 8px;
}
.kir-section-sub { font-size: 14px; color: var(--kg); line-height: 1.65; max-width: 520px; }
.kir-mb-0 { margin-bottom: 0 !important; }
.kir-link-cta { font-size: 13px; font-weight: 700; color: var(--ko); white-space: nowrap; }
.kir-link-cta:hover { opacity: .8; }

/* ── How it works ─────────────────────────────────────────────────────────── */
.kir-hiw { background: var(--color-background-secondary); }
.kir-hiw-steps {
  display: grid; grid-template-columns: repeat(4,1fr); gap: 16px;
}
.kir-hiw-step {
  background: var(--color-background-primary);
  border: .5px solid var(--color-border-tertiary);
  border-radius: 14px; padding: 20px 16px;
}
.kir-hiw-step-num {
  width: 32px; height: 32px; background: var(--ko); border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 13px; font-weight: 800; color: #fff; margin-bottom: 12px;
}
.kir-hiw-step-title { font-size: 14px; font-weight: 700; color: var(--kd); margin-bottom: 6px; }
.kir-hiw-step-desc  { font-size: 12px; color: var(--kg); line-height: 1.65; }

/* ── Popular destinations ─────────────────────────────────────────────────── */
.kir-dest-grid {
  display: grid; grid-template-columns: repeat(3,1fr); gap: 12px;
}
.kir-dest-card {
  display: flex; align-items: center; gap: 14px; padding: 14px 16px;
  background: var(--color-background-primary);
  border: .5px solid var(--color-border-tertiary);
  border-radius: 14px; cursor: pointer;
  transition: transform .15s, box-shadow .15s;
}
.kir-dest-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(0,0,0,.08);
  border-color: var(--ko);
}
.kir-dest-flag { font-size: 28px; flex-shrink: 0; width: 44px; text-align: center; }
.kir-dest-flag img { display: block; border-radius: 3px; }
.kir-dest-info { flex: 1; min-width: 0; }
.kir-dest-name { font-size: 14px; font-weight: 700; color: var(--kd); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.kir-dest-type { font-size: 10px; font-weight: 700; color: var(--kg); letter-spacing: .05em; margin-top: 2px; }
.kir-dest-arrow { font-size: 14px; color: var(--ko); flex-shrink: 0; }
.kir-dest-more { text-align: center; margin-top: 20px; }
.kir-dest-more a {
  font-size: 13px; font-weight: 700; color: var(--ko);
  border: .5px solid var(--ko); border-radius: var(--r-pill);
  padding: 10px 28px; display: inline-block; transition: background .15s;
}
.kir-dest-more a:hover { background: var(--ko); color: #fff; }

/* ── About Kirapp ─────────────────────────────────────────────────────────── */
.kir-about {
  background: linear-gradient(135deg, var(--kd) 0%, var(--kd2) 100%);
}
.kir-about-inner {
  display: grid; grid-template-columns: 1fr 1fr; gap: 48px; align-items: center;
}
.kir-about-badge {
  display: inline-flex; align-items: center;
  background: rgba(253,114,50,.15); border: 1px solid rgba(253,114,50,.3);
  border-radius: var(--r-pill); padding: 4px 14px; margin-bottom: 12px;
}
.kir-about-badge span { font-size: 10px; font-weight: 700; color: var(--ko); letter-spacing: .08em; }
.kir-about-title {
  font-size: clamp(20px,3vw,28px); font-weight: 800; color: #fff;
  letter-spacing: -.03em; margin-bottom: 14px; line-height: 1.2;
}
.kir-about-desc {
  font-size: 14px; color: rgba(255,255,255,.65); line-height: 1.75; margin-bottom: 20px;
}
.kir-about-features { list-style: none; display: flex; flex-direction: column; gap: 10px; }
.kir-about-features li { display: flex; align-items: flex-start; gap: 10px; }
.kir-about-dot {
  width: 6px; height: 6px; background: var(--kt); border-radius: 50%;
  margin-top: 6px; flex-shrink: 0;
}
.kir-about-features span:last-child { font-size: 13px; color: rgba(255,255,255,.7); line-height: 1.55; }
.kir-about-features strong { color: #fff; font-weight: 600; }
.kir-about-cta {
  display: inline-flex; align-items: center; gap: 8px;
  background: var(--ko); color: #fff; font-family: var(--font);
  font-size: 13px; font-weight: 700; padding: 12px 24px;
  border-radius: var(--r-pill); margin-top: 20px; transition: opacity .15s;
}
.kir-about-cta:hover { opacity: .9; }
.kir-about-stats { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.kir-about-stat {
  background: rgba(255,255,255,.06); border: .5px solid rgba(255,255,255,.1);
  border-radius: 14px; padding: 20px 16px; text-align: center;
}
.kir-about-stat-num {
  font-size: 28px; font-weight: 800; color: var(--ko);
  letter-spacing: -.03em; margin-bottom: 4px;
}
.kir-about-stat-lbl { font-size: 10px; color: rgba(255,255,255,.5); font-weight: 700; letter-spacing: .05em; }

/* ── Home blog grid ───────────────────────────────────────────────────────── */
.kir-home-blog-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 16px; }
.kir-home-blog-card {
  display: block; background: var(--color-background-primary);
  border: .5px solid var(--color-border-tertiary); border-radius: 14px;
  overflow: hidden; transition: transform .15s;
}
.kir-home-blog-card:hover { transform: translateY(-2px); }
.kir-home-blog-img {
  height: 150px; overflow: hidden; position: relative;
  background: linear-gradient(135deg, var(--kd2), var(--kd));
  display: flex; align-items: center; justify-content: center;
}
.kir-home-blog-img img { width: 100%; height: 100%; object-fit: cover; }
.kir-blog-placeholder { font-size: 36px; }
.kir-home-blog-tag {
  position: absolute; top: 10px; left: 10px;
  background: rgba(253,114,50,.9); border-radius: var(--r-pill);
  padding: 3px 9px; font-size: 9px; font-weight: 700; color: #fff; letter-spacing: .05em;
}
.kir-home-blog-body { padding: 14px 16px; }
.kir-home-blog-date { font-size: 11px; color: var(--kg); margin-bottom: 6px; }
.kir-home-blog-title { font-size: 14px; font-weight: 700; color: var(--kd); line-height: 1.35; margin-bottom: 6px; }
.kir-home-blog-excerpt {
  font-size: 12px; color: var(--kg); line-height: 1.55;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
}
.kir-home-blog-read { font-size: 12px; font-weight: 700; color: var(--ko); margin-top: 10px; display: inline-block; }

/* ── App download banner ──────────────────────────────────────────────────── */
.kir-app-banner { background: var(--kd); }
.kir-app-inner {
  display: grid; grid-template-columns: 1fr auto; gap: 32px;
  align-items: center; max-width: 900px; margin: 0 auto;
}
.kir-app-title { font-size: clamp(20px,3vw,28px); font-weight: 800; color: #fff; letter-spacing: -.03em; margin-bottom: 10px; }
.kir-app-sub   { font-size: 13px; color: rgba(255,255,255,.55); line-height: 1.65; margin-bottom: 20px; }
.kir-app-btns  { display: flex; gap: 10px; flex-wrap: wrap; }
.kir-app-btn {
  display: flex; align-items: center; gap: 10px;
  background: rgba(255,255,255,.1); border: .5px solid rgba(255,255,255,.2);
  border-radius: 10px; padding: 10px 16px; transition: background .15s;
}
.kir-app-btn:hover { background: rgba(255,255,255,.18); }
.kir-app-btn-icon { font-size: 20px; }
.kir-app-btn-sub  { font-size: 9px; color: rgba(255,255,255,.55); font-weight: 500; }
.kir-app-btn-name { font-size: 13px; font-weight: 700; color: #fff; }
.kir-app-qr {
  background: rgba(255,255,255,.06); border: .5px solid rgba(255,255,255,.1);
  border-radius: 14px; padding: 24px; text-align: center; min-width: 160px;
}
.kir-app-qr-box {
  width: 80px; height: 80px; background: rgba(255,255,255,.15);
  border-radius: 10px; margin: 0 auto 10px;
  display: flex; align-items: center; justify-content: center;
  font-size: 11px; color: rgba(255,255,255,.4); font-weight: 600;
}
.kir-app-qr-txt { font-size: 12px; color: rgba(255,255,255,.5); line-height: 1.5; }
.kir-app-qr-url { font-size: 12px; font-weight: 700; color: var(--ko); margin-top: 6px; }

/* ── Responsive ───────────────────────────────────────────────────────────── */
@media (max-width: 768px) {
  .kir-stats-grid      { grid-template-columns: repeat(2,1fr); }
  .kir-stat-item:nth-child(2) { border-right: none; }
  .kir-hiw-steps       { grid-template-columns: repeat(2,1fr); }
  .kir-dest-grid       { grid-template-columns: 1fr; }
  .kir-about-inner     { grid-template-columns: 1fr; }
  .kir-home-blog-grid  { grid-template-columns: 1fr; }
  .kir-app-inner       { grid-template-columns: 1fr; }
  .kir-app-qr          { display: none; }
}
@media (max-width: 480px) {
  .kir-hiw-steps       { grid-template-columns: 1fr; }
  .kir-hero-search     { flex-direction: column; }
  .kir-hero-search-btn { width: 100%; padding: 13px; }
}

/* ═══════════════════════════════════════════════════════════════════════════
   Auth styles
   ═══════════════════════════════════════════════════════════════════════════ */
.kir-auth-wrap {
  min-height: calc(100vh - 60px); display: flex;
  align-items: center; justify-content: center;
  padding: var(--sp-xl) var(--sp-lg);
  background: var(--color-background-secondary);
}
.kir-auth-card {
  background: var(--color-background-primary);
  border: .5px solid var(--color-border-tertiary);
  border-radius: 16px; width: 100%; max-width: 400px; padding: 32px 28px;
}
.kir-auth-logo {
  display: flex; align-items: center; justify-content: center;
  gap: 8px; margin-bottom: 24px;
}
.kir-auth-logo-icon {
  width: 36px; height: 36px; background: var(--ko); border-radius: 9px;
  display: flex; align-items: center; justify-content: center;
  font-weight: 800; font-size: 18px; color: #fff;
}
.kir-auth-logo-txt { font-weight: 800; font-size: 18px; color: var(--kd); letter-spacing: -.02em; }
.kir-auth-logo-txt em { color: var(--ko); font-style: normal; }
.kir-auth-title { font-size: 22px; font-weight: 800; color: var(--kd); letter-spacing: -.03em; margin-bottom: 6px; text-align: center; }
.kir-auth-sub   { font-size: 13px; color: var(--kg); text-align: center; line-height: 1.65; margin-bottom: 24px; }
.kir-auth-sub em { color: var(--ko); font-style: normal; font-weight: 600; }
.kir-auth-back {
  display: inline-flex; align-items: center; gap: 5px;
  font-size: 13px; font-weight: 600; color: var(--ko);
  margin-bottom: 20px; transition: opacity .15s;
}
.kir-auth-back:hover { opacity: .8; }

/* Social buttons */
.kir-auth-socials { display: flex; flex-direction: column; gap: 10px; margin-bottom: 20px; }
.kir-auth-social-btn {
  display: flex; align-items: center; justify-content: center; gap: 10px;
  padding: 12px; border: .5px solid var(--color-border-secondary);
  border-radius: 10px; background: var(--color-background-primary);
  font-family: var(--font); font-size: 14px; font-weight: 600; color: var(--kd);
  cursor: pointer; transition: background .15s;
}
.kir-auth-social-btn:hover { background: var(--color-background-secondary); }
.kir-social-icon { font-size: 18px; }
.kir-google-g { font-size: 16px; font-weight: 700; color: #4285F4; }

/* Divider */
.kir-auth-divider {
  display: flex; align-items: center; gap: 12px; margin-bottom: 20px;
  font-size: 11px; font-weight: 600; color: var(--kg); letter-spacing: .04em;
}
.kir-auth-divider-line { flex: 1; height: .5px; background: var(--color-border-tertiary); }

/* Alerts */
.kir-auth-alert {
  padding: 10px 12px; border-radius: 8px;
  font-size: 12px; margin-bottom: 14px; line-height: 1.5;
}
.kir-auth-alert--error  { background: rgba(226,75,74,.08); border: .5px solid rgba(226,75,74,.25); color: #A32D2D; }
.kir-auth-alert--success{ background: rgba(29,158,117,.08); border: .5px solid rgba(29,158,117,.25); color: #0F6E56; }

/* Form fields */
.kir-auth-field { margin-bottom: 14px; }
.kir-auth-label {
  display: block; font-size: 12px; font-weight: 600;
  color: var(--kd); margin-bottom: 6px; letter-spacing: .02em;
}
.kir-auth-input {
  width: 100%; padding: 12px 14px;
  border: 1.5px solid var(--color-border-secondary); border-radius: 10px;
  font-family: var(--font); font-size: 14px; color: var(--kd);
  background: var(--color-background-primary); outline: none; transition: border-color .15s;
}
.kir-auth-input:focus { border-color: var(--ko); }
.kir-auth-input-row { position: relative; }
.kir-auth-input-row .kir-auth-input { padding-right: 44px; }
.kir-auth-eye {
  position: absolute; right: 12px; top: 50%; transform: translateY(-50%);
  background: none; border: none; cursor: pointer; color: var(--kg); font-size: 15px;
}

/* Password strength */
.kir-strength { display: flex; gap: 4px; margin-top: 6px; }
.kir-strength-bar {
  flex: 1; height: 3px; border-radius: 2px;
  background: var(--color-border-tertiary); transition: background .2s;
}

/* Primary button */
.kir-auth-btn {
  width: 100%; padding: 13px; background: var(--ko); border: none;
  border-radius: 10px; font-family: var(--font); font-size: 14px; font-weight: 700;
  color: #fff; cursor: pointer; transition: opacity .15s; margin-top: 4px;
}
.kir-auth-btn:hover { opacity: .9; }

/* Footer / links */
.kir-auth-footer { text-align: center; margin-top: 20px; font-size: 13px; color: var(--kg); }
.kir-auth-footer a { color: var(--ko); font-weight: 600; }
.kir-auth-link-sm { font-size: 12px; font-weight: 600; color: var(--ko); }
.kir-auth-terms   { font-size: 12px; color: var(--kg); text-align: center; margin-top: 12px; line-height: 1.55; }
.kir-auth-terms a { color: var(--ko); font-weight: 600; }

/* OTP */
.kir-otp {
  display: flex; gap: 10px; justify-content: center;
  margin: 8px 0 20px;
}
.kir-otp-inp {
  width: 52px; height: 60px;
  border: 1.5px solid var(--color-border-secondary); border-radius: 10px;
  font-family: var(--font); font-size: 24px; font-weight: 700;
  color: var(--kd); text-align: center;
  background: var(--color-background-primary); outline: none; transition: border-color .15s;
}
.kir-otp-inp:focus { border-color: var(--ko); }
.kir-otp-inp--filled { border-color: var(--kt); background: rgba(93,195,199,.05); }
.kir-otp--6 .kir-otp-inp { width: 42px; font-size: 20px; }
.kir-otp-resend    { text-align: center; font-size: 12px; color: var(--kg); margin-top: 12px; }
.kir-otp-resend a  { color: var(--ko); font-weight: 600; }
.kir-otp-countdown { color: var(--ko); font-weight: 600; }

@media (max-width: 440px) {
  .kir-auth-card { padding: 24px 18px; border-radius: 0; border: none; }
  .kir-auth-wrap { padding: 0; align-items: flex-start; }
  .kir-otp-inp { width: 44px; height: 52px; font-size: 20px; }
  .kir-otp--6 .kir-otp-inp { width: 36px; }
}

/* ═══════════════════════════════════════════════════════════════════════════
   Plans — Search & Detail styles
   ═══════════════════════════════════════════════════════════════════════════ */

/* ── Search header ────────────────────────────────────────────────────────── */
.kir-plans-header {
  background: linear-gradient(135deg, var(--kd) 0%, var(--kd2) 100%);
  padding: var(--sp-xxl) var(--sp-lg) var(--sp-xl);
}
.kir-plans-title {
  font-size: clamp(22px,4vw,32px); font-weight: 800; color: #fff;
  letter-spacing: -.03em; margin-bottom: 6px;
}
.kir-plans-sub { font-size: 13px; color: rgba(255,255,255,.5); margin-bottom: 20px; }
.kir-plans-search-row { display: flex; gap: 8px; max-width: 600px; }
.kir-plans-search-inp {
  flex: 1; padding: 12px 14px; border: none; border-radius: 10px;
  font-family: var(--font); font-size: 14px; color: var(--kd); outline: none;
}
.kir-plans-search-btn {
  background: var(--ko); border: none; color: #fff;
  font-family: var(--font); font-size: 13px; font-weight: 700;
  padding: 0 20px; border-radius: 10px; cursor: pointer;
}

/* ── Filter bar ───────────────────────────────────────────────────────────── */
.kir-plans-filters {
  background: var(--color-background-primary);
  border-bottom: .5px solid var(--color-border-tertiary);
  position: sticky; top: 60px; z-index: 50;
}
.kir-plans-filter-scroll {
  display: flex; overflow-x: auto; gap: 0; padding: 0 var(--sp-lg);
}
.kir-plans-filter-scroll::-webkit-scrollbar { display: none; }
.kir-plans-filter-btn {
  padding: 12px 16px; font-family: var(--font); font-size: 12px; font-weight: 600;
  color: var(--kg); border: none; background: none; cursor: pointer;
  border-bottom: 2px solid transparent; white-space: nowrap; transition: color .15s;
}
.kir-plans-filter-btn.active { color: var(--ko); border-bottom-color: var(--ko); }
.kir-plans-filter-btn:hover:not(.active) { color: var(--kd); }

/* ── Results ─────────────────────────────────────────────────────────────── */
.kir-plans-results-wrap { background: var(--color-background-secondary); }
.kir-plans-results-bar {
  display: flex; align-items: center; justify-content: space-between;
  padding: 12px 0; margin-bottom: var(--sp-md);
}
.kir-plans-results-count { font-size: 12px; color: var(--kg); font-weight: 500; }
.kir-plans-results-count strong { color: var(--kd); }
.kir-plans-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 10px;
}

/* ── Plan card ───────────────────────────────────────────────────────────── */
.kir-plans-card {
  display: flex; align-items: center; gap: 14px; padding: 14px 16px;
  background: var(--color-background-primary);
  border: .5px solid var(--color-border-tertiary);
  border-radius: 12px; cursor: pointer;
  transition: border-color .15s, transform .1s;
}
.kir-plans-card:hover { border-color: var(--ko); transform: translateY(-1px); }
.kir-plans-card--skeleton {
  height: 66px; background: var(--color-background-primary);
  border-radius: 12px; animation: kirPulse 1.4s ease-in-out infinite;
}
@keyframes kirPulse { 0%,100%{opacity:1} 50%{opacity:.4} }
.kir-plans-card-flag { width: 44px; flex-shrink: 0; text-align: center; }
.kir-plans-card-flag img { display: block; border-radius: 3px; }
.kir-plans-card-info { flex: 1; min-width: 0; }
.kir-plans-card-name { font-size: 14px; font-weight: 700; color: var(--kd); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.kir-plans-card-meta { display: flex; gap: 6px; align-items: center; margin-top: 3px; }
.kir-plans-card-type { font-size: 10px; font-weight: 700; color: var(--kg); letter-spacing: .04em; }
.kir-plans-card-arrow { font-size: 13px; color: var(--ko); flex-shrink: 0; }

/* Empty state */
.kir-plans-empty {
  text-align: center; padding: 48px var(--sp-lg);
  grid-column: 1 / -1;
}
.kir-plans-empty-icon  { font-size: 36px; margin-bottom: 12px; }
.kir-plans-empty-title { font-size: 15px; font-weight: 700; color: var(--kd); margin-bottom: 6px; }
.kir-plans-empty-sub   { font-size: 13px; color: var(--kg); }

/* ── Detail — back ────────────────────────────────────────────────────────── */
.kir-plans-back {
  background: var(--color-background-primary);
  border-bottom: .5px solid var(--color-border-tertiary);
  padding: 12px var(--sp-lg);
}
.kir-plans-back-link { font-size: 13px; font-weight: 600; color: var(--ko); }
.kir-plans-back-link:hover { opacity: .8; }

/* ── Detail — hero ────────────────────────────────────────────────────────── */
.kir-pd-hero {
  background: linear-gradient(135deg, var(--kd) 0%, var(--kd2) 100%);
  padding: var(--sp-xl) 0 0;
}
.kir-pd-hero .kir-container { padding-bottom: 0; }
.kir-pd-hero-info {
  display: flex; align-items: center; gap: 14px; margin-bottom: 20px;
}
.kir-pd-flag img { display: block; border-radius: 4px; }
.kir-pd-dest-name { font-size: clamp(22px,4vw,30px); font-weight: 800; color: #fff; letter-spacing: -.03em; }
.kir-pd-dest-type { font-size: 11px; font-weight: 600; color: rgba(255,255,255,.5); letter-spacing: .05em; margin-top: 2px; }

/* ── Bundle selector ─────────────────────────────────────────────────────── */
.kir-pd-bundles {
  display: flex; gap: 8px; overflow-x: auto; padding-bottom: var(--sp-md);
}
.kir-pd-bundles::-webkit-scrollbar { display: none; }
.kir-pd-bundle-card {
  background: rgba(255,255,255,.08); border: .5px solid rgba(255,255,255,.15);
  border-radius: 12px; padding: 12px 14px; min-width: 108px; flex-shrink: 0;
  cursor: pointer; transition: all .15s; text-align: center;
}
.kir-pd-bundle-card:hover { background: rgba(255,255,255,.14); }
.kir-pd-bundle-card.active { background: var(--ko); border-color: var(--ko); }
.kir-pd-bundle-skeleton { height: 80px; animation: kirPulse 1.4s ease-in-out infinite; }
.kir-pd-bundle-gb    { font-size: 17px; font-weight: 800; color: #fff; letter-spacing: -.02em; }
.kir-pd-bundle-days  { font-size: 11px; color: rgba(255,255,255,.55); margin: 3px 0; }
.kir-pd-bundle-price { font-size: 13px; font-weight: 700; color: var(--kt); }
.kir-pd-bundle-card.active .kir-pd-bundle-days  { color: rgba(255,255,255,.8); }
.kir-pd-bundle-card.active .kir-pd-bundle-price { color: #fff; }

/* ── Tabs ─────────────────────────────────────────────────────────────────── */
.kir-pd-tabs {
  background: var(--color-background-primary);
  border-bottom: .5px solid var(--color-border-tertiary);
  position: sticky; top: 60px; z-index: 40; overflow-x: auto;
}
.kir-pd-tabs::-webkit-scrollbar { display: none; }
.kir-pd-tabs .kir-container { display: flex; padding: 0 var(--sp-lg); }
.kir-pd-tab {
  flex: 1; padding: 12px 8px; font-family: var(--font); font-size: 12px; font-weight: 600;
  color: var(--kg); border: none; background: none; cursor: pointer;
  border-bottom: 2px solid transparent; white-space: nowrap; transition: color .15s; text-align: center;
}
.kir-pd-tab.active { color: var(--ko); border-bottom-color: var(--ko); }
.kir-pd-tab:hover:not(.active) { color: var(--kd); }
.kir-pd-tab-content { display: none; }
.kir-pd-tab-content.active { display: block; }
.kir-pd-loading { font-size: 13px; color: var(--kg); padding: 20px 0; }

/* Coverage */
.kir-pd-coverage-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(180px,1fr)); gap: 8px; }
.kir-pd-coverage-item {
  display: flex; align-items: center; gap: 8px; padding: 10px 12px;
  background: var(--color-background-secondary); border-radius: 8px;
  border: .5px solid var(--color-border-tertiary);
}
.kir-pd-coverage-name { font-size: 13px; font-weight: 500; color: var(--kd); }

/* Networks */
.kir-pd-network-list { display: flex; flex-direction: column; gap: 8px; }
.kir-pd-network-item {
  display: flex; align-items: center; justify-content: space-between;
  padding: 12px 14px; background: var(--color-background-secondary);
  border-radius: 10px; border: .5px solid var(--color-border-tertiary);
}
.kir-pd-network-name { font-size: 13px; font-weight: 600; color: var(--kd); }
.kir-pd-network-type {
  font-size: 11px; font-weight: 700; color: var(--kt);
  background: rgba(93,195,199,.1); border-radius: var(--r-pill); padding: 2px 8px;
}

/* Policy */
.kir-pd-policy-list { display: flex; flex-direction: column; gap: 8px; }
.kir-pd-policy-item {
  display: flex; align-items: center; justify-content: space-between; gap: 12px;
  padding: 12px 14px; background: var(--color-background-secondary);
  border-radius: 10px; border: .5px solid var(--color-border-tertiary);
}
.kir-pd-policy-label { font-size: 12px; font-weight: 600; color: var(--kg); margin-bottom: 2px; }
.kir-pd-policy-val   { font-size: 14px; font-weight: 700; color: var(--kd); }
.kir-pd-policy-badge { font-size: 11px; font-weight: 700; padding: 3px 9px; border-radius: var(--r-pill); white-space: nowrap; flex-shrink: 0; }
.kir-pd-policy-badge--yes { background: rgba(29,158,117,.1); color: #0F6E56; }
.kir-pd-policy-badge--no  { background: rgba(150,150,150,.1); color: var(--kg); }

/* Compat notice */
.kir-pd-compat-notice {
  background: rgba(93,195,199,.07); border: .5px solid rgba(93,195,199,.2);
  border-radius: 10px; padding: 14px 16px; font-size: 13px; color: var(--kd2); line-height: 1.65;
}
.kir-pd-compat-notice strong { color: var(--kt); font-weight: 600; }

/* ── Sticky buy bar ───────────────────────────────────────────────────────── */
.kir-pd-buy-bar {
  position: sticky; bottom: 0;
  background: var(--color-background-primary);
  border-top: .5px solid var(--color-border-tertiary);
  padding: 14px var(--sp-lg);
  display: flex; align-items: center; justify-content: space-between; gap: 16px;
}
.kir-pd-buy-price { font-size: 24px; font-weight: 800; color: var(--ko); letter-spacing: -.02em; }
.kir-pd-buy-meta  { font-size: 11px; color: var(--kg); margin-top: 2px; }
.kir-pd-buy-btn {
  background: var(--ko); border: none; color: #fff;
  font-family: var(--font); font-size: 14px; font-weight: 700;
  padding: 13px 32px; border-radius: var(--r-pill); cursor: pointer;
  transition: opacity .15s; flex-shrink: 0;
}
.kir-pd-buy-btn:hover:not(:disabled) { opacity: .9; }
.kir-pd-buy-btn:disabled { background: var(--kg); cursor: not-allowed; opacity: .6; }

/* ── Responsive ───────────────────────────────────────────────────────────── */
@media (max-width: 768px) {
  .kir-plans-grid { grid-template-columns: 1fr; }
  .kir-pd-coverage-grid { grid-template-columns: 1fr; }
}
@media (max-width: 480px) {
  .kir-plans-search-row { flex-direction: column; }
  .kir-plans-search-btn { padding: 12px; }
  .kir-pd-bundle-card { min-width: 88px; padding: 10px; }
  .kir-pd-buy-btn { padding: 12px 20px; font-size: 13px; }
}

/* ═══════════════════════════════════════════════════════════════════════════
   Checkout styles
   ═══════════════════════════════════════════════════════════════════════════ */

/* ── Stepper ──────────────────────────────────────────────────────────────── */
.kir-co-stepper {
  background: var(--color-background-primary);
  border-bottom: .5px solid var(--color-border-tertiary);
  padding: 14px var(--sp-lg);
}
.kir-co-steps {
  display: flex; align-items: center; gap: 0;
  max-width: 480px; margin: 0 auto;
}
.kir-co-step { display: flex; align-items: center; gap: 6px; flex: 1; }
.kir-co-step-num {
  width: 24px; height: 24px; border-radius: 50%; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  font-size: 11px; font-weight: 700;
  background: var(--color-background-secondary);
  color: var(--kg); border: .5px solid var(--color-border-secondary);
}
.kir-co-step.active .kir-co-step-num { background: var(--ko); color: #fff; border-color: var(--ko); }
.kir-co-step.done   .kir-co-step-num { background: var(--kt); color: #fff; border-color: var(--kt); }
.kir-co-step-lbl { font-size: 11px; font-weight: 600; color: var(--kg); }
.kir-co-step.active .kir-co-step-lbl { color: var(--ko); }
.kir-co-step.done   .kir-co-step-lbl { color: var(--kt); }
.kir-co-step-line { flex: 1; height: .5px; background: var(--color-border-tertiary); margin: 0 6px; }
.kir-co-step-line.done { background: var(--kt); }

/* ── Layout ───────────────────────────────────────────────────────────────── */
.kir-co-layout {
  display: grid; grid-template-columns: 1fr 320px; gap: 20px;
  align-items: start;
}
.kir-co-main { display: flex; flex-direction: column; gap: 16px; }
.kir-co-side { display: flex; flex-direction: column; gap: 14px; }
.kir-co-step-panel { display: none; }
.kir-co-step-panel.active { display: contents; }

/* ── Cards ────────────────────────────────────────────────────────────────── */
.kir-co-card {
  background: var(--color-background-primary);
  border: .5px solid var(--color-border-tertiary); border-radius: 14px; overflow: hidden;
}
.kir-co-card-header {
  padding: 13px 16px; border-bottom: .5px solid var(--color-border-tertiary);
}
.kir-co-card-title { font-size: 13px; font-weight: 700; color: var(--kd); }
.kir-co-card-body  { padding: 16px; }

/* ── Order summary ────────────────────────────────────────────────────────── */
.kir-co-plan-name { font-size: 16px; font-weight: 800; color: var(--kd); letter-spacing: -.02em; margin-bottom: 12px; }
.kir-co-plan-pills { display: flex; gap: 6px; flex-wrap: wrap; margin-bottom: 12px; }
.kir-co-plan-pill {
  display: flex; align-items: center; gap: 6px;
  background: var(--color-background-secondary); border-radius: 8px; padding: 6px 10px;
}
.kir-co-plan-pill-ico { font-size: 14px; }
.kir-co-plan-pill-val { font-size: 12px; font-weight: 700; color: var(--kd); }
.kir-co-plan-pill-lbl { font-size: 10px; color: var(--kg); margin-top: 1px; }
.kir-co-plan-coverage { font-size: 12px; color: var(--kg); margin-bottom: 12px; }
.kir-co-plan-coverage strong { color: var(--kd); font-weight: 600; }
.kir-co-divider { height: .5px; background: var(--color-border-tertiary); margin: 12px 0; }
.kir-co-price-row { display: flex; justify-content: space-between; align-items: center; margin-bottom: 6px; }
.kir-co-price-lbl { font-size: 13px; color: var(--kg); }
.kir-co-price-val { font-size: 13px; font-weight: 600; color: var(--kd); }
.kir-co-price-discount { color: #0F6E56 !important; }
.kir-co-price-total-row { display: flex; justify-content: space-between; align-items: center; margin-top: 10px; }
.kir-co-price-total-lbl { font-size: 14px; font-weight: 700; color: var(--kd); }
.kir-co-price-total-val { font-size: 24px; font-weight: 800; color: var(--ko); letter-spacing: -.02em; }

/* ── Discount section ─────────────────────────────────────────────────────── */
.kir-co-discount-tabs {
  display: flex; gap: 0; border-bottom: .5px solid var(--color-border-tertiary); margin-bottom: 14px;
}
.kir-co-discount-tab {
  flex: 1; padding: 9px; font-family: var(--font); font-size: 12px; font-weight: 600;
  color: var(--kg); border: none; background: none; cursor: pointer;
  border-bottom: 2px solid transparent; transition: color .15s;
}
.kir-co-discount-tab.active { color: var(--ko); border-bottom-color: var(--ko); }
.kir-co-discount-panel { display: none; }
.kir-co-discount-panel.active { display: block; }
.kir-co-coupon-row { display: flex; gap: 8px; }
.kir-co-coupon-inp {
  flex: 1; padding: 10px 12px;
  border: 1.5px solid var(--color-border-secondary); border-radius: 8px;
  font-family: var(--font); font-size: 13px; color: var(--kd);
  background: var(--color-background-primary); outline: none; transition: border-color .15s;
}
.kir-co-coupon-inp:focus { border-color: var(--ko); }
.kir-co-coupon-btn {
  background: var(--ko); border: none; color: #fff;
  font-family: var(--font); font-size: 12px; font-weight: 700;
  padding: 0 16px; border-radius: 8px; cursor: pointer;
}
.kir-co-coupon-result { margin-top: 10px; font-size: 12px; padding: 8px 10px; border-radius: 7px; line-height: 1.5; }
.kir-co-alert-success { background: rgba(29,158,117,.08); border: .5px solid rgba(29,158,117,.2); color: #0F6E56; }
.kir-co-alert-error   { background: rgba(226,75,74,.08);  border: .5px solid rgba(226,75,74,.2);  color: #A32D2D; }
.kir-co-cashback-list { display: flex; flex-direction: column; gap: 8px; }
.kir-co-cashback-item {
  display: flex; align-items: center; gap: 10px; padding: 10px 12px;
  border: .5px solid var(--color-border-secondary); border-radius: 8px;
  cursor: pointer; transition: border-color .15s;
}
.kir-co-cashback-item.selected { border-color: var(--ko); background: rgba(253,114,50,.04); }
.kir-co-cashback-radio {
  width: 16px; height: 16px; border-radius: 50%; flex-shrink: 0;
  border: 1.5px solid var(--color-border-secondary);
  display: flex; align-items: center; justify-content: center; transition: all .15s;
}
.kir-co-cashback-item.selected .kir-co-cashback-radio { border-color: var(--ko); background: var(--ko); }
.kir-co-cashback-dot { width: 6px; height: 6px; border-radius: 50%; background: #fff; display: none; }
.kir-co-cashback-item.selected .kir-co-cashback-dot { display: block; }
.kir-co-cashback-val  { font-size: 13px; font-weight: 700; color: var(--kd); }
.kir-co-cashback-desc { font-size: 11px; color: var(--kg); }

/* ── Payment form ─────────────────────────────────────────────────────────── */
.kir-co-payment-field { margin-bottom: 14px; }
.kir-co-payment-label { display: block; font-size: 12px; font-weight: 600; color: var(--kd); margin-bottom: 6px; letter-spacing: .02em; }
.kir-co-stripe-field {
  padding: 12px 14px;
  border: 1.5px solid var(--color-border-secondary); border-radius: 8px;
  background: var(--color-background-primary); min-height: 44px;
}
.kir-co-card-row { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.kir-co-secure-badge { display: flex; align-items: center; gap: 6px; font-size: 11px; color: var(--kg); margin-top: 8px; }
.kir-co-back-link { font-size: 12px; font-weight: 600; color: var(--ko); }

/* ── Submit button ────────────────────────────────────────────────────────── */
.kir-co-submit-btn {
  width: 100%; padding: 14px; background: var(--ko); border: none;
  border-radius: 10px; font-family: var(--font); font-size: 15px; font-weight: 700;
  color: #fff; cursor: pointer; transition: opacity .15s;
}
.kir-co-submit-btn:hover:not(:disabled) { opacity: .9; }
.kir-co-submit-btn:disabled { background: var(--kg); cursor: not-allowed; }
.kir-co-loading { font-size: 13px; color: var(--kg); padding: 12px 0; }

/* ── Success page ─────────────────────────────────────────────────────────── */
.kir-co-success-wrap { max-width: 520px; margin: 0 auto; text-align: center; }
.kir-co-success-icon {
  width: 72px; height: 72px;
  background: rgba(29,158,117,.1); border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  margin: 0 auto var(--sp-lg); font-size: 32px;
}
.kir-co-success-title { font-size: clamp(22px,4vw,28px); font-weight: 800; color: var(--kd); letter-spacing: -.03em; margin-bottom: 8px; }
.kir-co-success-sub   { font-size: 14px; color: var(--kg); line-height: 1.65; margin-bottom: var(--sp-xl); }
.kir-co-qr-card {
  background: var(--color-background-primary);
  border: .5px solid var(--color-border-tertiary);
  border-radius: 16px; padding: 24px; margin-bottom: var(--sp-lg);
}
.kir-co-qr-plan-title { font-size: 15px; font-weight: 700; color: var(--kd); margin-bottom: 4px; }
.kir-co-qr-sub        { font-size: 12px; color: var(--kg); line-height: 1.6; margin-bottom: 16px; }
.kir-co-qr-box {
  width: 200px; height: 200px;
  background: var(--color-background-secondary);
  border-radius: 12px; margin: 0 auto 14px;
  display: flex; align-items: center; justify-content: center;
  border: .5px solid var(--color-border-tertiary); overflow: hidden;
}
.kir-co-qr-box img { display: block; }
.kir-co-lpa-code {
  font-size: 11px; color: var(--kg); font-family: monospace;
  word-break: break-all; line-height: 1.5; padding: 8px 12px;
  background: var(--color-background-secondary); border-radius: 8px;
  margin-bottom: 14px;
}
.kir-co-qr-actions { display: flex; gap: 8px; justify-content: center; flex-wrap: wrap; }
.kir-co-qr-btn {
  display: flex; align-items: center; gap: 6px;
  padding: 9px 16px; border-radius: 8px;
  font-family: var(--font); font-size: 12px; font-weight: 700; cursor: pointer;
}
.kir-co-qr-btn-primary { background: var(--ko); color: #fff; border: none; }
.kir-co-qr-btn-ghost   { background: none; border: .5px solid var(--color-border-secondary); color: var(--kd); }
.kir-co-success-hint {
  font-size: 12px; color: var(--kg); line-height: 1.65;
  background: var(--color-background-secondary); border-radius: 10px;
  padding: 12px 16px; margin-bottom: var(--sp-lg); text-align: left;
}
.kir-co-success-hint a { color: var(--ko); font-weight: 600; }
.kir-co-success-actions { display: flex; gap: 10px; justify-content: center; flex-wrap: wrap; }
.kir-co-success-cta {
  font-size: 13px; font-weight: 700; color: var(--ko);
  padding: 10px 24px; border: .5px solid var(--ko); border-radius: var(--r-pill);
  transition: background .15s;
}
.kir-co-success-cta:hover { background: var(--ko); color: #fff; }
.kir-co-success-cta--ghost { color: var(--kd); border-color: var(--color-border-secondary); }
.kir-co-success-cta--ghost:hover { background: var(--color-background-secondary); color: var(--kd); }

/* ── Responsive ───────────────────────────────────────────────────────────── */
@media (max-width: 768px) {
  .kir-co-layout { grid-template-columns: 1fr; }
  .kir-co-side   { order: -1; }
}
@media (max-width: 480px) {
  .kir-co-card-row { grid-template-columns: 1fr; }
}

/* ═══════════════════════════════════════════════════════════════════════════
   Account styles
   ═══════════════════════════════════════════════════════════════════════════ */

/* ── Layout ───────────────────────────────────────────────────────────────── */
.kir-acc-layout {
  display: grid; grid-template-columns: 220px 1fr;
  min-height: calc(100vh - 60px);
}
.kir-acc-sidebar {
  background: var(--color-background-primary);
  border-right: .5px solid var(--color-border-tertiary);
  padding: 20px 0; position: sticky; top: 60px;
  height: calc(100vh - 60px); overflow-y: auto;
}
.kir-acc-content {
  background: var(--color-background-secondary);
  padding: 24px; min-height: 100%;
}
.kir-acc-page-title { font-size: 20px; font-weight: 800; color: var(--kd); letter-spacing: -.02em; margin-bottom: 20px; }

/* ── Sidebar user ─────────────────────────────────────────────────────────── */
.kir-acc-user {
  padding: 16px 20px 14px;
  border-bottom: .5px solid var(--color-border-tertiary); margin-bottom: 8px;
}
.kir-acc-avatar {
  width: 44px; height: 44px; background: var(--ko); border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 18px; font-weight: 800; color: #fff; margin-bottom: 10px;
}
.kir-acc-username { font-size: 14px; font-weight: 700; color: var(--kd); margin-bottom: 2px; }
.kir-acc-email    { font-size: 11px; color: var(--kg); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; max-width: 190px; }

/* ── Sidebar nav ──────────────────────────────────────────────────────────── */
.kir-acc-nav-item {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 20px; font-size: 13px; font-weight: 600; color: var(--kg);
  cursor: pointer; transition: all .15s;
  border-left: 3px solid transparent; background: none; border-top: none; border-right: none; border-bottom: none;
  font-family: var(--font); width: 100%; text-align: left;
}
.kir-acc-nav-item:hover   { background: var(--color-background-secondary); color: var(--kd); }
.kir-acc-nav-item.active  { color: var(--ko); border-left-color: var(--ko); background: rgba(253,114,50,.04); }
.kir-acc-nav-icon         { font-size: 15px; width: 18px; text-align: center; }
.kir-acc-nav-divider      { height: .5px; background: var(--color-border-tertiary); margin: 12px 0; }
.kir-acc-nav-logout       { color: var(--ko); }

/* ── Empty state ──────────────────────────────────────────────────────────── */
.kir-acc-empty { text-align: center; padding: 48px 20px; }
.kir-acc-empty-icon  { font-size: 40px; margin-bottom: 12px; }
.kir-acc-empty-title { font-size: 16px; font-weight: 700; color: var(--kd); margin-bottom: 6px; }
.kir-acc-empty-sub   { font-size: 13px; color: var(--kg); margin-bottom: 16px; }
.kir-acc-empty-cta   {
  display: inline-block; font-size: 13px; font-weight: 700; color: var(--ko);
  border: .5px solid var(--ko); border-radius: var(--r-pill); padding: 10px 24px;
}

/* ── eSIM cards ───────────────────────────────────────────────────────────── */
.kir-acc-esim-list { display: flex; flex-direction: column; gap: 14px; max-width: 700px; }
.kir-acc-esim-card {
  background: var(--color-background-primary);
  border: .5px solid var(--color-border-tertiary); border-radius: 14px; padding: 16px;
}
.kir-acc-esim-header { display: flex; align-items: flex-start; justify-content: space-between; margin-bottom: 14px; }
.kir-acc-esim-name   { font-size: 15px; font-weight: 700; color: var(--kd); margin-bottom: 2px; }
.kir-acc-esim-iccid  { font-size: 10px; font-family: monospace; color: var(--kg); }
.kir-acc-esim-status { font-size: 10px; font-weight: 700; padding: 3px 9px; border-radius: var(--r-pill); flex-shrink: 0; }
.kir-acc-status-registered { background: rgba(93,195,199,.12); color: #0F6E56; }
.kir-acc-status-active     { background: rgba(29,158,117,.12); color: #0F6E56; }
.kir-acc-status-finished   { background: rgba(150,150,150,.1); color: var(--kg); }
.kir-acc-esim-stats { display: grid; grid-template-columns: repeat(3,1fr); gap: 8px; margin-bottom: 14px; }
.kir-acc-esim-stat  { background: var(--color-background-secondary); border-radius: 8px; padding: 8px 10px; }
.kir-acc-esim-stat-val { font-size: 13px; font-weight: 700; color: var(--kd); }
.kir-acc-esim-stat-lbl { font-size: 10px; color: var(--kg); margin-top: 1px; }
.kir-acc-esim-expire { font-size: 11px; color: var(--kg); margin-bottom: 12px; }
.kir-acc-esim-actions { display: flex; gap: 8px; }
.kir-acc-esim-btn {
  flex: 1; padding: 9px; border-radius: 8px;
  font-family: var(--font); font-size: 12px; font-weight: 700; cursor: pointer;
  text-align: center; transition: opacity .15s;
}
.kir-acc-esim-btn-primary { background: var(--ko); color: #fff; border: none; }
.kir-acc-esim-btn-primary:hover { opacity: .9; }
.kir-acc-esim-btn-ghost { background: none; border: .5px solid var(--color-border-secondary); color: var(--kd); }

/* ── Order list ───────────────────────────────────────────────────────────── */
.kir-acc-order-list { display: flex; flex-direction: column; gap: 10px; max-width: 700px; }
.kir-acc-order-card {
  display: flex; align-items: center; gap: 14px; padding: 14px 16px;
  background: var(--color-background-primary);
  border: .5px solid var(--color-border-tertiary); border-radius: 12px;
  cursor: pointer; transition: border-color .15s;
}
.kir-acc-order-card:hover { border-color: var(--ko); }
.kir-acc-order-icon  { width: 40px; height: 40px; background: rgba(253,114,50,.1); border-radius: 10px; display: flex; align-items: center; justify-content: center; font-size: 18px; flex-shrink: 0; }
.kir-acc-order-info  { flex: 1; min-width: 0; }
.kir-acc-order-title { font-size: 14px; font-weight: 700; color: var(--kd); margin-bottom: 2px; }
.kir-acc-order-num   { font-size: 11px; font-family: monospace; color: var(--kg); }
.kir-acc-order-date  { font-size: 11px; color: var(--kg); margin-top: 3px; }
.kir-acc-order-right { text-align: right; flex-shrink: 0; }
.kir-acc-order-price  { font-size: 15px; font-weight: 800; color: var(--ko); }
.kir-acc-order-coupon { font-size: 10px; color: #0F6E56; font-weight: 600; margin-top: 2px; }

/* ── Balance ──────────────────────────────────────────────────────────────── */
.kir-acc-balance-hero {
  background: linear-gradient(135deg, var(--kd), var(--kd2));
  border-radius: 14px; padding: 24px; margin-bottom: 20px; text-align: center;
  max-width: 460px;
}
.kir-acc-balance-lbl    { font-size: 10px; font-weight: 700; color: rgba(255,255,255,.5); letter-spacing: .06em; margin-bottom: 6px; }
.kir-acc-balance-amount { font-size: 52px; font-weight: 800; color: var(--ko); letter-spacing: -.04em; line-height: 1; }
.kir-acc-balance-desc   { font-size: 12px; color: rgba(255,255,255,.45); margin-top: 8px; }
.kir-acc-tx-title { font-size: 11px; font-weight: 700; color: var(--kg); letter-spacing: .05em; margin-bottom: 10px; }
.kir-acc-tx-list  { display: flex; flex-direction: column; gap: 8px; max-width: 460px; }
.kir-acc-tx-item  {
  display: flex; align-items: center; justify-content: space-between;
  padding: 12px 14px; background: var(--color-background-primary);
  border-radius: 10px; border: .5px solid var(--color-border-tertiary);
}
.kir-acc-tx-left  { display: flex; align-items: center; gap: 10px; }
.kir-acc-tx-icon  { width: 32px; height: 32px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 13px; font-weight: 700; flex-shrink: 0; }
.kir-acc-tx-income-icon  { background: rgba(29,158,117,.1); color: #0F6E56; }
.kir-acc-tx-expense-icon { background: rgba(253,114,50,.1);  color: var(--ko); }
.kir-acc-tx-desc { font-size: 13px; font-weight: 600; color: var(--kd); }
.kir-acc-tx-date { font-size: 11px; color: var(--kg); }
.kir-acc-tx-amount { font-size: 14px; font-weight: 700; }
.kir-acc-tx-income-val  { color: #0F6E56; }
.kir-acc-tx-expense-val { color: var(--ko); }

/* ── Profile ──────────────────────────────────────────────────────────────── */
.kir-acc-profile-card {
  background: var(--color-background-primary);
  border: .5px solid var(--color-border-tertiary); border-radius: 14px;
  padding: 20px; max-width: 500px;
}
.kir-acc-profile-avatar-row {
  display: flex; align-items: center; gap: 14px; margin-bottom: 20px;
  padding-bottom: 16px; border-bottom: .5px solid var(--color-border-tertiary);
}
.kir-acc-profile-avatar {
  width: 56px; height: 56px; background: var(--ko); border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 22px; font-weight: 800; color: #fff; flex-shrink: 0;
}
.kir-acc-profile-name  { font-size: 17px; font-weight: 800; color: var(--kd); letter-spacing: -.02em; }
.kir-acc-profile-email { font-size: 12px; color: var(--kg); margin-top: 2px; }
.kir-acc-pf-field { margin-bottom: 14px; }
.kir-acc-pf-label { display: block; font-size: 12px; font-weight: 600; color: var(--kd); margin-bottom: 6px; letter-spacing: .02em; }
.kir-acc-pf-input {
  width: 100%; padding: 11px 13px;
  border: 1.5px solid var(--color-border-secondary); border-radius: 8px;
  font-family: var(--font); font-size: 14px; color: var(--kd);
  background: var(--color-background-primary); outline: none; transition: border-color .15s;
}
.kir-acc-pf-input:focus { border-color: var(--ko); }
.kir-acc-eye {
  position: absolute; right: 12px; top: 50%; transform: translateY(-50%);
  background: none; border: none; cursor: pointer; color: var(--kg); font-size: 15px;
}
.kir-acc-social-notice {
  background: rgba(93,195,199,.07); border: .5px solid rgba(93,195,199,.2);
  border-radius: 8px; padding: 10px 12px; font-size: 12px; color: var(--kd2);
  line-height: 1.65; margin-bottom: 14px;
}
.kir-acc-social-notice strong { color: var(--kt); font-weight: 600; }
.kir-acc-save-btn {
  background: var(--ko); border: none; color: #fff;
  font-family: var(--font); font-size: 14px; font-weight: 700;
  padding: 12px 28px; border-radius: 10px; cursor: pointer; transition: opacity .15s;
}
.kir-acc-save-btn:hover { opacity: .9; }
.kir-acc-alert { font-size: 12px; padding: 9px 12px; border-radius: 8px; margin-bottom: 14px; line-height: 1.5; }
.kir-acc-alert-success { background: rgba(29,158,117,.08); border: .5px solid rgba(29,158,117,.2); color: #0F6E56; }
.kir-acc-alert-error   { background: rgba(226,75,74,.08);  border: .5px solid rgba(226,75,74,.2);  color: #A32D2D; }

/* ── Modals (shared: QR + order) ──────────────────────────────────────────── */
.kir-acc-modal-wrap {
  display: none; position: fixed; inset: 0;
  background: rgba(0,0,0,.45); z-index: 200;
  align-items: center; justify-content: center; padding: 20px;
}
.kir-acc-modal-wrap.open { display: flex; }
.kir-acc-modal {
  background: var(--color-background-primary); border-radius: 16px;
  width: 100%; max-width: 420px; overflow: hidden;
}
.kir-acc-modal-header {
  padding: 20px; position: relative; display: flex; flex-direction: column; gap: 4px;
}
.kir-acc-modal-header--dark { background: linear-gradient(135deg, var(--kd), var(--kd2)); }
.kir-acc-modal-title  { font-size: 15px; font-weight: 700; color: var(--kd); }
.kir-acc-modal-close  {
  position: absolute; top: 14px; right: 14px;
  background: rgba(255,255,255,.15); border: none; border-radius: 50%;
  width: 28px; height: 28px; display: flex; align-items: center; justify-content: center;
  cursor: pointer; color: #fff; font-size: 13px;
}
.kir-acc-modal-data-lbl { font-size: 10px; font-weight: 700; color: rgba(255,255,255,.5); letter-spacing: .06em; }
.kir-acc-modal-data-val { font-size: 26px; font-weight: 800; color: var(--ko); letter-spacing: -.03em; }
.kir-acc-modal-body    { padding: 20px; }
.kir-acc-modal-section { margin-bottom: 16px; }
.kir-acc-modal-section-title { font-size: 12px; font-weight: 700; color: var(--kd); margin-bottom: 10px; }
.kir-acc-modal-row     { display: flex; justify-content: space-between; align-items: center; padding: 9px 0; border-bottom: .5px solid var(--color-border-tertiary); }
.kir-acc-modal-row:last-child { border-bottom: none; }
.kir-acc-modal-lbl     { font-size: 13px; color: var(--kg); }
.kir-acc-modal-val     { font-size: 13px; font-weight: 600; color: var(--kd); }
.kir-mono              { font-family: monospace; font-size: 12px; }
.kir-acc-lpa-code {
  font-size: 11px; color: var(--kg); font-family: monospace;
  word-break: break-all; line-height: 1.5; padding: 8px;
  background: var(--color-background-secondary); border-radius: 8px; margin-bottom: 4px;
}
.kir-acc-qr-btn-primary,.kir-acc-qr-btn-ghost {
  display: inline-flex; align-items: center; gap: 6px; padding: 9px 16px;
  border-radius: 8px; font-family: var(--font); font-size: 12px; font-weight: 700; cursor: pointer;
}
.kir-acc-qr-btn-primary { background: var(--ko); color: #fff; border: none; }
.kir-acc-qr-btn-ghost   { background: none; border: .5px solid var(--color-border-secondary); color: var(--kd); }

/* ── Responsive ───────────────────────────────────────────────────────────── */
@media (max-width: 768px) {
  .kir-acc-layout { grid-template-columns: 1fr; }
  .kir-acc-sidebar { position: static; height: auto; border-right: none; border-bottom: .5px solid var(--color-border-tertiary); padding: 12px 0; }
  .kir-acc-esim-stats { grid-template-columns: 1fr 1fr; }
}

/* ═══════════════════════════════════════════════════════════════════════════
   404 Error page
   ═══════════════════════════════════════════════════════════════════════════ */
.kir-404-wrap {
  min-height: calc(100vh - 60px);
  display: flex; align-items: center; justify-content: center;
  padding: var(--sp-xl) var(--sp-lg);
  background: var(--color-background-secondary);
}
.kir-404-inner { text-align: center; max-width: 420px; }
.kir-404-num {
  font-size: 96px; font-weight: 800; color: var(--ko);
  letter-spacing: -.06em; line-height: 1; margin-bottom: 12px;
  opacity: .9;
}
.kir-404-title {
  font-size: 26px; font-weight: 800; color: var(--kd);
  letter-spacing: -.03em; margin-bottom: 10px;
}
.kir-404-sub {
  font-size: 14px; color: var(--kg); line-height: 1.7;
  margin-bottom: var(--sp-xl);
}
.kir-404-actions {
  display: flex; gap: 10px; justify-content: center;
  flex-wrap: wrap; margin-bottom: var(--sp-lg);
}
.kir-404-btn-primary {
  display: inline-block; background: var(--ko); color: #fff;
  font-family: var(--font); font-size: 14px; font-weight: 700;
  padding: 12px 28px; border-radius: var(--r-pill); transition: opacity .15s;
}
.kir-404-btn-primary:hover { opacity: .9; }
.kir-404-btn-ghost {
  display: inline-block; color: var(--kd);
  font-family: var(--font); font-size: 14px; font-weight: 700;
  padding: 12px 28px; border-radius: var(--r-pill);
  border: .5px solid var(--color-border-secondary); transition: background .15s;
}
.kir-404-btn-ghost:hover { background: var(--color-background-secondary); }
.kir-404-links {
  display: flex; align-items: center; gap: 8px; justify-content: center;
  font-size: 12px; color: var(--kg); flex-wrap: wrap;
}
.kir-404-links a { color: var(--ko); font-weight: 600; }

/* ═══════════════════════════════════════════════════════════════════════════
   About page
   ═══════════════════════════════════════════════════════════════════════════ */
.kir-about-page-hero {
  background: linear-gradient(135deg, var(--kd) 0%, var(--kd2) 100%);
  padding: var(--sp-xxl) var(--sp-lg) var(--sp-xl);
}
.kir-about-page-title {
  font-size: clamp(24px,4vw,36px); font-weight: 800; color: #fff;
  letter-spacing: -.03em; margin-bottom: 10px;
}
.kir-about-page-sub {
  font-size: 15px; color: rgba(255,255,255,.6); line-height: 1.7;
  max-width: 580px;
}

/* Two-column layout */
.kir-about-page-layout {
  display: grid; grid-template-columns: 1fr 300px; gap: 40px; align-items: start;
}
.kir-about-page-intro {
  font-size: 15px; color: var(--kd2); line-height: 1.8;
  margin-bottom: var(--sp-xl);
}
.kir-about-page-h2 {
  font-size: 18px; font-weight: 800; color: var(--kd);
  letter-spacing: -.02em; margin-bottom: 16px;
  padding-bottom: 8px; border-bottom: 2px solid var(--ko);
  display: inline-block;
}

/* Steps */
.kir-about-steps { display: flex; flex-direction: column; gap: 16px; margin-bottom: var(--sp-xl); }
.kir-about-step  { display: flex; align-items: flex-start; gap: 14px; }
.kir-about-step-num {
  width: 30px; height: 30px; background: var(--ko); border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 13px; font-weight: 800; color: #fff; flex-shrink: 0; margin-top: 2px;
}
.kir-about-step-title { font-size: 14px; font-weight: 700; color: var(--kd); margin-bottom: 3px; }
.kir-about-step-desc  { font-size: 13px; color: var(--kg); line-height: 1.6; }

/* Features */
.kir-about-features { list-style: none; display: flex; flex-direction: column; gap: 10px; }
.kir-about-feature  { display: flex; align-items: flex-start; gap: 10px; font-size: 14px; color: var(--kd); line-height: 1.6; }
.kir-about-feature-dot {
  width: 6px; height: 6px; background: var(--kt); border-radius: 50%;
  margin-top: 7px; flex-shrink: 0;
}

/* Side cards */
.kir-about-page-side { display: flex; flex-direction: column; gap: 14px; }

.kir-about-stats-card {
  background: linear-gradient(135deg, var(--kd), var(--kd2));
  border-radius: 14px; padding: 20px;
  display: grid; grid-template-columns: 1fr 1fr; gap: 12px;
}
.kir-about-stat-item { text-align: center; }
.kir-about-stat-num { font-size: 26px; font-weight: 800; color: var(--ko); letter-spacing: -.03em; }
.kir-about-stat-lbl { font-size: 10px; font-weight: 600; color: rgba(255,255,255,.5); letter-spacing: .04em; margin-top: 2px; }

.kir-about-cta-card {
  background: var(--color-background-primary);
  border: .5px solid var(--color-border-tertiary); border-radius: 14px; padding: 18px;
}
.kir-about-cta-title { font-size: 15px; font-weight: 700; color: var(--kd); margin-bottom: 5px; }
.kir-about-cta-sub   { font-size: 12px; color: var(--kg); line-height: 1.6; margin-bottom: 14px; }
.kir-about-cta-btn {
  display: block; text-align: center; background: var(--ko); color: #fff;
  font-family: var(--font); font-size: 13px; font-weight: 700;
  padding: 11px; border-radius: 10px; margin-bottom: 14px; transition: opacity .15s;
}
.kir-about-cta-btn:hover { opacity: .9; }
.kir-about-cta-app-lbl   { font-size: 10px; font-weight: 700; color: var(--kg); letter-spacing: .05em; margin-bottom: 8px; }
.kir-about-cta-app-links { display: flex; gap: 8px; }
.kir-about-app-btn {
  flex: 1; text-align: center; padding: 8px;
  background: var(--color-background-secondary); border-radius: 8px;
  font-size: 11px; font-weight: 700; color: var(--kd);
  border: .5px solid var(--color-border-tertiary); transition: background .15s;
}
.kir-about-app-btn:hover { background: var(--color-background-primary); }

.kir-about-contact-card {
  background: var(--color-background-primary);
  border: .5px solid var(--color-border-tertiary); border-radius: 14px; padding: 18px;
}
.kir-about-contact-title    { font-size: 12px; font-weight: 700; color: var(--kg); letter-spacing: .05em; margin-bottom: 10px; }
.kir-about-contact-link     { display: block; font-size: 13px; font-weight: 600; color: var(--ko); margin-bottom: 6px; }
.kir-about-contact-location { font-size: 12px; color: var(--kg); margin-top: 8px; }

@media (max-width: 768px) {
  .kir-about-page-layout { grid-template-columns: 1fr; }
  .kir-about-page-side { order: -1; }
  .kir-about-stats-card { grid-template-columns: repeat(4,1fr); }
}
@media (max-width: 480px) {
  .kir-about-stats-card { grid-template-columns: repeat(2,1fr); }
}

/* ── Compatibility tab — EID check ───────────────────────────────────────── */
.kir-pd-compat-eid {
  background: var(--color-background-secondary);
  border: .5px solid var(--color-border-tertiary);
  border-radius: 12px; padding: 16px 18px; margin-bottom: 14px;
}
.kir-pd-compat-eid-title {
  font-size: 13px; font-weight: 700; color: var(--kd); margin-bottom: 12px;
}
.kir-pd-compat-steps {
  list-style: none; display: flex; flex-direction: column; gap: 8px;
  padding: 0; margin: 0 0 14px; counter-reset: eid-steps;
}
.kir-pd-compat-steps li {
  display: flex; align-items: center; gap: 10px;
  font-size: 13px; color: var(--kd); line-height: 1.5;
  counter-increment: eid-steps;
}
.kir-pd-compat-steps li::before {
  content: counter(eid-steps);
  min-width: 22px; height: 22px; border-radius: 50%;
  background: var(--ko); color: #fff;
  font-size: 11px; font-weight: 700;
  display: flex; align-items: center; justify-content: center; flex-shrink: 0;
}
.kir-pd-compat-code {
  font-family: monospace; font-size: 14px; font-weight: 700;
  color: var(--ko); letter-spacing: .05em;
  background: rgba(253,114,50,.08); padding: 2px 7px; border-radius: 5px;
}
.kir-pd-compat-result {
  display: flex; align-items: flex-start; gap: 8px;
  background: rgba(29,158,117,.07); border: .5px solid rgba(29,158,117,.2);
  border-radius: 8px; padding: 10px 12px;
  font-size: 13px; color: var(--kd); line-height: 1.6;
}
.kir-pd-compat-arrow { font-size: 15px; color: #0F6E56; flex-shrink: 0; margin-top: 1px; }
