
  :root{
    --ink:#0A2540;
    --ink-soft:#123a63;
    --sky:#2F9BFF;
    --sky-soft:#7ec4ff;
    --paper:#F5F8FC;
    --white:#FFFFFF;
    --gold:#F5B942;
    --text-dim:#5C7092;
    --line: rgba(10,37,64,0.10);
    --radius-lg: 28px;
    --radius-md: 18px;
    --radius-sm: 12px;
    --shadow-soft: 0 20px 50px -20px rgba(10,37,64,0.25);
    --font-display: 'Space Grotesk', sans-serif;
    --font-body: 'Inter', sans-serif;
    --font-mono: 'IBM Plex Mono', monospace;
  }

  *{ box-sizing:border-box; margin:0; padding:0; }
  html{ scroll-behavior:smooth; }
  body{
    font-family: var(--font-body);
    color: var(--ink);
    background: var(--paper);
    -webkit-font-smoothing:antialiased;
    overflow-x:hidden;
  }
  img,svg{ display:block; max-width:100%; }
  a{ color:inherit; text-decoration:none; }
  ul{ list-style:none; }
  button{ font-family:inherit; cursor:pointer; border:none; background:none; }
  .container{ max-width:1240px; margin:0 auto; padding:0 32px; }
  section{ position:relative; }
  .eyebrow{
    display:inline-flex; align-items:center; gap:8px;
    font-family: var(--font-mono);
    font-size:12px; letter-spacing:0.08em; text-transform:uppercase;
    color: var(--sky);
    background: rgba(47,155,255,0.09);
    border:1px solid rgba(47,155,255,0.25);
    padding:7px 14px 7px 10px;
    border-radius:999px;
  }
  .eyebrow .dot{ width:6px; height:6px; border-radius:50%; background:var(--sky); box-shadow:0 0 0 3px rgba(47,155,255,0.2); }

  h1,h2,h3{ font-family: var(--font-display); font-weight:600; letter-spacing:-0.02em; color:var(--ink); }
  .lede{ color: var(--text-dim); line-height:1.65; }

  /* ---------- KITE STRING SIGNATURE ---------- */
  #kite-string{
    position:absolute; left:50%; top:0; width:2px; height:100%;
    transform:translateX(-50%);
    z-index:0; pointer-events:none;
  }
  .string-path{
    fill:none; stroke: rgba(10,37,64,0.14); stroke-width:2; stroke-dasharray:1 10; stroke-linecap:round;
  }

  /* ---------- NAV ---------- */
  header{
    position:sticky; top:0; z-index:50;
    background: rgba(245,248,252,0.82);
    backdrop-filter: blur(14px);
    border-bottom:1px solid var(--line);
  }
  nav{ display:flex; align-items:center; justify-content:space-between; padding:18px 0; }
  .logo{ display:flex; align-items:center; gap:10px; font-family:var(--font-display); font-weight:700; font-size:19px; }
  .logo svg{ width:26px; height:26px; }
  .nav-links{ display:flex; gap:34px; font-size:14.5px; font-weight:500; }
  .nav-links a{ position:relative; color:var(--ink-soft); transition:color .2s; }
  .nav-links a:hover{ color:var(--sky); }
  .nav-actions{ display:flex; align-items:center; gap:12px; }
  .btn{
    display:inline-flex; align-items:center; justify-content:center; gap:8px;
    padding:11px 22px; border-radius:999px; font-weight:600; font-size:14.5px;
    transition: transform .18s ease, box-shadow .18s ease, background .18s ease;
    white-space:nowrap;
  }
  .btn-primary{ background: var(--ink); color:var(--white); }
  .btn-primary:hover{ background: var(--sky); box-shadow: 0 10px 24px -8px rgba(47,155,255,0.55); transform:translateY(-1px); }
  .btn-ghost{ color: var(--ink); font-weight:600; padding:11px 16px; }
  .btn-ghost:hover{ color: var(--sky); }
  .btn-outline{ border:1.5px solid rgba(10,37,64,0.18); color:var(--ink); }
  .btn-outline:hover{ border-color: var(--sky); color:var(--sky); }
  .menu-toggle{ display:none; flex-direction:column; gap:5px; }
  .menu-toggle span{ width:22px; height:2px; background:var(--ink); border-radius:2px; }

  /* ---------- HERO ---------- */
  .hero{ padding:96px 0 70px; overflow:visible; }
  .hero-inner{ display:grid; grid-template-columns:1.05fr 1fr; gap:56px; align-items:center; }
  .hero h1{ font-size:clamp(38px,5vw,60px); line-height:1.04; margin:20px 0 22px; }
  .hero h1 .accent{ color: var(--sky); }
  .hero .lede{ font-size:17px; max-width:460px; margin-bottom:32px; }
  .hero-cta{ display:flex; gap:14px; align-items:center; margin-bottom:38px; }
  .hero-meta{ display:flex; gap:28px; }
  .hero-meta div{ font-family:var(--font-mono); font-size:12px; color:var(--text-dim); }
  .hero-meta strong{ display:block; font-family:var(--font-display); font-size:20px; color:var(--ink); }

  .hero-visual{ position:relative; height:480px; }
  .kite-mark{ position:absolute; top:-46px; right:26px; width:64px; opacity:.9; animation: float 6s ease-in-out infinite; }
  @keyframes float{ 0%,100%{ transform:translateY(0) rotate(-4deg);} 50%{ transform:translateY(-14px) rotate(4deg);} }

  .glass-card{
    position:absolute; background:rgba(255,255,255,0.72);
    border:1px solid rgba(255,255,255,0.6);
    backdrop-filter: blur(18px);
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-soft);
    padding:20px 22px;
  }
  .card-balance{ top:0; left:0; width:280px; }
  .card-balance .label{ font-size:12px; color:var(--text-dim); margin-bottom:6px; }
  .card-balance .amt{ font-family:var(--font-mono); font-size:28px; font-weight:500; letter-spacing:-0.01em; }
  .card-balance .sub{ font-size:12px; color:#1FAA59; margin-top:8px; }

  .card-send{
    top:150px; right:0; width:300px;
    background: linear-gradient(155deg, var(--ink) 0%, #163f6b 100%);
    color:#fff; border:none;
  }
  .card-send .eyebrow{ background:rgba(255,255,255,0.12); color:#bfe0ff; border-color:rgba(255,255,255,0.2); }
  .card-send h3{ color:#fff; font-size:22px; margin:14px 0 8px; }
  .card-send p{ font-size:13px; color:#c8d9ec; line-height:1.55; }

  .card-fx{ bottom:20px; left:40px; width:250px; }
  .fx-row{ display:flex; justify-content:space-between; align-items:center; font-size:13px; padding:7px 0; }
  .fx-row .flag{ width:20px; height:20px; border-radius:50%; margin-right:8px; display:inline-block; vertical-align:middle; }
  .fx-row .amt-neg{ color:#D9622B; font-family:var(--font-mono); font-size:13px; }
  .fx-row .amt-pos{ color:#1FAA59; font-family:var(--font-mono); font-size:13px; }
  .fx-divider{ height:1px; background:var(--line); margin:2px 0; }

  .flight-line{ position:absolute; inset:0; z-index:-1; }

  /* ---------- TRUST BAR ---------- */
  .trust{ border-top:1px solid var(--line); border-bottom:1px solid var(--line); background:var(--white); padding:34px 0; }
  .trust-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:24px; text-align:center; }
  .trust-grid strong{ display:block; font-family:var(--font-display); font-size:26px; }
  .trust-grid span{ font-size:12.5px; color:var(--text-dim); }

  /* ---------- SECTION HEADS ---------- */
  .section-head{ max-width:600px; margin:0 auto 52px; text-align:center; }
  .section-head h2{ font-size:clamp(28px,3.4vw,40px); margin:16px 0 12px; }
  .section-head .lede{ margin:0 auto; }
  .section-pad{ padding:110px 0; }

  /* ---------- FEATURES ---------- */
  .feature-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
  .feature-card{
    background:var(--white); border:1px solid var(--line); border-radius: var(--radius-md);
    padding:30px 26px; transition: transform .25s ease, box-shadow .25s ease;
  }
  .feature-card:hover{ transform:translateY(-6px); box-shadow: var(--shadow-soft); }
  .feature-icon{
    width:46px; height:46px; border-radius:13px; display:flex; align-items:center; justify-content:center;
    background: linear-gradient(155deg, var(--sky) 0%, #1b6fd6 100%); margin-bottom:20px;
  }
  .feature-icon svg{ width:22px; height:22px; stroke:#fff; }
  .feature-card h3{ font-size:18.5px; margin-bottom:8px; }
  .feature-card p{ font-size:14px; color:var(--text-dim); line-height:1.6; }

  /* ---------- PRODUCTS ---------- */
  .product-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:2px; background:var(--line); border:1px solid var(--line); border-radius: var(--radius-lg); overflow:hidden; }
  .product-tile{ background:var(--white); padding:34px 30px; transition: background .2s ease; }
  .product-tile:hover{ background: #FBFDFF; }
  .product-tile .tag{ font-family:var(--font-mono); font-size:11px; color:var(--sky); letter-spacing:.06em; text-transform:uppercase; }
  .product-tile h3{ font-size:19px; margin:12px 0 8px; }
  .product-tile p{ font-size:13.5px; color:var(--text-dim); line-height:1.6; margin-bottom:16px; }
  .product-tile .go{ font-size:13px; font-weight:600; color:var(--ink); display:inline-flex; align-items:center; gap:6px; }
  .product-tile .go svg{ width:14px; height:14px; transition: transform .2s; }
  .product-tile:hover .go svg{ transform:translateX(3px); }

  /* ---------- HOW IT WORKS ---------- */
  .steps{ display:grid; grid-template-columns:repeat(3,1fr); gap:0; position:relative; }
  .step{ padding:0 26px; position:relative; }
  .step-num{ font-family:var(--font-mono); font-size:13px; color:var(--sky); margin-bottom:16px; display:block; }
  .step h3{ font-size:19px; margin-bottom:10px; }
  .step p{ font-size:14px; color:var(--text-dim); line-height:1.6; }
  .steps::before{
    content:''; position:absolute; top:8px; left:16.6%; right:16.6%; height:1px;
    background-image: linear-gradient(to right, rgba(10,37,64,0.22) 0, rgba(10,37,64,0.22) 6px, transparent 6px, transparent 14px);
    background-size:14px 1px;
  }

  /* ---------- SECURITY ---------- */
  .security{ background: var(--ink); color:#fff; border-radius: var(--radius-lg); padding:70px 60px; }
  .security .section-head h2, .security .section-head .eyebrow{ color:#fff; }
  .security .section-head .eyebrow{ background:rgba(255,255,255,0.1); border-color:rgba(255,255,255,0.2); color:#bfe0ff;}
  .security .section-head .lede{ color:#a9c1dc; }
  .badge-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px; }
  .badge{ background:rgba(255,255,255,0.06); border:1px solid rgba(255,255,255,0.12); border-radius: var(--radius-sm); padding:22px 18px; }
  .badge svg{ width:22px; height:22px; stroke:#7ec4ff; margin-bottom:14px; }
  .badge h4{ font-family:var(--font-display); font-size:15.5px; margin-bottom:6px; }
  .badge p{ font-size:12.5px; color:#a9c1dc; line-height:1.55; }

  /* ---------- DASHBOARD PREVIEW ---------- */
  .dash-mock{
    background:var(--white); border:1px solid var(--line); border-radius: var(--radius-lg);
    box-shadow: var(--shadow-soft); overflow:hidden; display:grid; grid-template-columns:220px 1fr;
  }
  .dash-side{ background:var(--ink); color:#fff; padding:26px 18px; }
  .dash-side .dlogo{ font-family:var(--font-display); font-weight:700; font-size:15px; margin-bottom:26px; display:flex; align-items:center; gap:8px;}
  .dash-side ul li{ font-size:13.5px; padding:10px 12px; border-radius:9px; color:#b9cde3; margin-bottom:2px; }
  .dash-side ul li.active{ background:rgba(255,255,255,0.12); color:#fff; font-weight:600; }
  .dash-main{ padding:30px 34px; }
  .dash-top{ display:flex; justify-content:space-between; align-items:center; margin-bottom:24px; }
  .dash-top h4{ font-family:var(--font-display); font-size:20px; }
  .dash-top .pill{ font-family:var(--font-mono); font-size:11.5px; background:rgba(31,170,89,0.1); color:#1FAA59; padding:6px 12px; border-radius:999px; }
  .widget-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:14px; margin-bottom:24px; }
  .widget{ background:var(--paper); border:1px solid var(--line); border-radius: var(--radius-sm); padding:16px; }
  .widget .w-label{ font-size:11.5px; color:var(--text-dim); margin-bottom:6px; }
  .widget .w-amt{ font-family:var(--font-mono); font-size:19px; }
  .widget .w-delta{ font-size:11px; margin-top:6px; }
  .up{ color:#1FAA59; } .down{ color:#D9622B; }
  .dash-chart{ background:var(--paper); border:1px solid var(--line); border-radius: var(--radius-sm); padding:18px; height:140px; }

  /* ---------- FAQ ---------- */
  .faq-list{ max-width:760px; margin:0 auto; display:flex; flex-direction:column; gap:10px; }
  .faq-item{ background:var(--white); border:1px solid var(--line); border-radius: var(--radius-sm); overflow:hidden; }
  .faq-q{ width:100%; display:flex; justify-content:space-between; align-items:center; padding:19px 22px; font-size:15px; font-weight:500; text-align:left; }
  .faq-q .plus{ width:26px; height:26px; border-radius:50%; border:1.5px solid rgba(10,37,64,0.18); position:relative; flex-shrink:0; transition: transform .25s ease, background .25s ease; }
  .faq-q .plus::before, .faq-q .plus::after{ content:''; position:absolute; background:var(--ink); top:50%; left:50%; transform:translate(-50%,-50%); }
  .faq-q .plus::before{ width:10px; height:1.5px; }
  .faq-q .plus::after{ width:1.5px; height:10px; transition: opacity .2s ease; }
  .faq-item.open .plus{ background:var(--ink); transform:rotate(180deg); }
  .faq-item.open .plus::before, .faq-item.open .plus::after{ background:#fff; }
  .faq-item.open .plus::after{ opacity:0; }
  .faq-a{ max-height:0; overflow:hidden; transition: max-height .3s ease; }
  .faq-a p{ padding:0 22px 20px; font-size:14px; color:var(--text-dim); line-height:1.65; }

  /* ---------- CTA / FOOTER ---------- */
  .cta-band{
    background: linear-gradient(150deg, var(--ink) 0%, #0f4a7c 60%, var(--sky) 130%);
    border-radius: var(--radius-lg); padding:60px 56px; color:#fff;
    display:grid; grid-template-columns:1.2fr 1fr; gap:40px; align-items:center;
  }
  .cta-band h2{ color:#fff; font-size:clamp(24px,2.8vw,32px); margin-bottom:12px; }
  .cta-band p{ color:#cfe3f7; font-size:14.5px; max-width:400px; }
  .cta-form{ display:flex; flex-direction:column; gap:10px; }
  .cta-form input{
    padding:14px 16px; border-radius:12px; border:1px solid rgba(255,255,255,0.25);
    background:rgba(255,255,255,0.1); color:#fff; font-family:inherit; font-size:14px;
  }
  .cta-form input::placeholder{ color:#cfe3f7; }
  .cta-form button{ margin-top:4px; }

  footer{ padding:70px 0 30px; }
  .foot-grid{ display:grid; grid-template-columns:1.4fr repeat(3,1fr); gap:40px; margin-bottom:50px; }
  .foot-brand .logo{ margin-bottom:14px; }
  .foot-brand p{ font-size:13.5px; color:var(--text-dim); max-width:260px; line-height:1.6; }
  .foot-col h5{ font-family:var(--font-mono); font-size:11.5px; text-transform:uppercase; letter-spacing:.07em; color:var(--text-dim); margin-bottom:16px; }
  .foot-col ul li{ margin-bottom:11px; font-size:14px; }
  .foot-col ul li a:hover{ color:var(--sky); }
  .foot-bottom{ display:flex; justify-content:space-between; align-items:center; padding-top:26px; border-top:1px solid var(--line); font-size:12.5px; color:var(--text-dim); flex-wrap:wrap; gap:12px; }
  .foot-social{ display:flex; gap:14px; }
  .foot-social a{ width:34px; height:34px; border-radius:50%; border:1px solid var(--line); display:flex; align-items:center; justify-content:center; }
  .foot-social a:hover{ border-color:var(--sky); color:var(--sky); }
  .disclaimer{ text-align:center; font-size:11.5px; color:var(--text-dim); margin-top:20px; opacity:.8; }

  [data-reveal]{ opacity:0; transform:translateY(18px); transition: opacity .6s ease, transform .6s ease; }
  [data-reveal].in{ opacity:1; transform:translateY(0); }

  @media (max-width: 980px){
    .hero-inner{ grid-template-columns:1fr; }
    .hero-visual{ height:420px; margin-top:20px; }
    .feature-grid, .product-grid{ grid-template-columns:1fr 1fr; }
    .steps{ grid-template-columns:1fr; gap:34px; }
    .steps::before{ display:none; }
    .trust-grid{ grid-template-columns:1fr 1fr; gap:26px; }
    .badge-grid{ grid-template-columns:1fr 1fr; }
    .foot-grid{ grid-template-columns:1fr 1fr; }
    .cta-band{ grid-template-columns:1fr; }
    .dash-mock{ grid-template-columns:1fr; }
    .dash-side{ display:none; }
    .widget-grid{ grid-template-columns:1fr 1fr; }
  }
  @media (max-width: 680px){
    .nav-links{ display:none; }
    .menu-toggle{ display:flex; }
    .feature-grid, .product-grid{ grid-template-columns:1fr; }
    .trust-grid{ grid-template-columns:1fr 1fr; }
    .badge-grid{ grid-template-columns:1fr; }
    .foot-grid{ grid-template-columns:1fr 1fr; }
    .container{ padding:0 20px; }
    .security{ padding:46px 24px; }
    .cta-band{ padding:40px 26px; }
    .widget-grid{ grid-template-columns:1fr 1fr; }
    .hero{ padding:60px 0 40px; }
  }

  @media (prefers-reduced-motion: reduce){
    *{ animation:none !important; transition:none !important; }
  }

/* =========================================================
   APP SHELL — customer dashboard & admin-facing pages
   ========================================================= */
.app-shell{ display:grid; grid-template-columns:240px 1fr; min-height:100vh; }
.app-sidebar{
  background: var(--ink); color:#fff; padding:26px 16px; position:sticky; top:0; height:100vh;
  display:flex; flex-direction:column; justify-content:space-between;
}
.app-sidebar .dlogo{ font-family:var(--font-display); font-weight:700; font-size:16px; display:flex; align-items:center; gap:8px; padding:0 10px 22px; }
.app-sidebar nav ul li{ margin-bottom:2px; }
.app-sidebar nav ul li a{ display:flex; align-items:center; gap:10px; font-size:13.5px; padding:10px 12px; border-radius:9px; color:#b9cde3; transition: background .15s, color .15s; }
.app-sidebar nav ul li a:hover{ background:rgba(255,255,255,0.08); color:#fff; }
.app-sidebar nav ul li a.active{ background:rgba(255,255,255,0.14); color:#fff; font-weight:600; }
.app-sidebar .sidebar-foot{ font-size:12px; color:#7f9cbd; padding:0 10px; }
.app-main{ padding:32px 40px; max-width:1180px; }
.app-topbar{ display:flex; justify-content:space-between; align-items:center; margin-bottom:28px; flex-wrap:wrap; gap:14px; }
.app-topbar h1{ font-size:24px; }
.app-topbar .user-chip{ display:flex; align-items:center; gap:10px; font-size:13.5px; color:var(--text-dim); }
.app-topbar .avatar{ width:34px; height:34px; border-radius:50%; background:var(--sky); color:#fff; display:flex; align-items:center; justify-content:center; font-family:var(--font-display); font-weight:600; font-size:13px; }

.widgets{ display:grid; grid-template-columns:repeat(4,1fr); gap:16px; margin-bottom:26px; }
.wcard{ background:var(--white); border:1px solid var(--line); border-radius: var(--radius-sm); padding:18px 20px; }
.wcard .w-label{ font-size:12px; color:var(--text-dim); margin-bottom:8px; }
.wcard .w-amt{ font-family:var(--font-mono); font-size:21px; }

.panel{ background:var(--white); border:1px solid var(--line); border-radius: var(--radius-md); padding:26px; margin-bottom:24px; }
.panel-head{ display:flex; justify-content:space-between; align-items:center; margin-bottom:18px; }
.panel-head h2{ font-size:17px; }
.panel-head a{ font-size:13px; font-weight:600; color:var(--sky); }

table.kc-table{ width:100%; border-collapse:collapse; font-size:13.5px; }
table.kc-table th{ text-align:left; font-family:var(--font-mono); font-size:11px; text-transform:uppercase; letter-spacing:.05em; color:var(--text-dim); padding:10px 12px; border-bottom:1px solid var(--line); }
table.kc-table td{ padding:13px 12px; border-bottom:1px solid var(--line); }
table.kc-table tr:last-child td{ border-bottom:none; }
.amt-pos{ color:#1FAA59; font-family:var(--font-mono); }
.amt-neg{ color:#D9622B; font-family:var(--font-mono); }
.status-pill{ font-family:var(--font-mono); font-size:11px; padding:4px 10px; border-radius:999px; text-transform:capitalize; }
.status-successful,.status-completed,.status-active,.status-approved,.status-verified{ background:rgba(31,170,89,0.1); color:#1FAA59; }
.status-pending{ background:rgba(245,185,66,0.15); color:#a9720c; }
.status-failed,.status-rejected,.status-frozen,.status-suspended{ background:rgba(217,98,43,0.12); color:#D9622B; }
.status-reversed,.status-closed{ background:rgba(10,37,64,0.08); color:var(--text-dim); }

.kc-form{ display:flex; flex-direction:column; gap:16px; max-width:520px; }
.kc-form .field{ display:flex; flex-direction:column; gap:6px; }
.kc-form label{ font-size:13px; font-weight:600; color:var(--ink); }
.kc-form input, .kc-form select, .kc-form textarea{
  font-family: var(--font-body); font-size:14px; padding:12px 14px; border-radius:12px;
  border:1.5px solid var(--line); background:var(--paper); color:var(--ink);
}
.kc-form input:focus, .kc-form select:focus, .kc-form textarea:focus{ outline:none; border-color:var(--sky); background:#fff; }
.kc-form .help{ font-size:12px; color:var(--text-dim); }
.kc-form .errorlist{ list-style:none; color:#D9622B; font-size:12.5px; padding:0; margin:0; }
.form-errors{ background:rgba(217,98,43,0.08); border:1px solid rgba(217,98,43,0.25); color:#D9622B; padding:12px 16px; border-radius:10px; font-size:13.5px; margin-bottom:16px; }

.auth-shell{ min-height:100vh; display:grid; grid-template-columns:1fr 1fr; }
.auth-visual{ background: linear-gradient(155deg, var(--ink), #0f4a7c); display:flex; align-items:center; justify-content:center; padding:60px; }
.auth-visual .msg{ color:#fff; max-width:380px; }
.auth-visual .msg h2{ color:#fff; font-size:28px; margin:16px 0 10px; }
.auth-visual .msg p{ color:#cfe3f7; font-size:14.5px; line-height:1.6; }
.auth-form-side{ display:flex; align-items:center; justify-content:center; padding:40px; }
.auth-box{ width:100%; max-width:400px; }
.auth-box h1{ font-size:26px; margin:14px 0 8px; }
.auth-box .sub{ color:var(--text-dim); font-size:14px; margin-bottom:26px; }
.auth-foot{ margin-top:20px; font-size:13.5px; color:var(--text-dim); text-align:center; }

.messages{ list-style:none; padding:0; margin:0 0 20px; display:flex; flex-direction:column; gap:8px; }
.messages li{ padding:12px 16px; border-radius:10px; font-size:13.5px; }
.messages .success{ background:rgba(31,170,89,0.1); color:#1FAA59; border:1px solid rgba(31,170,89,0.25); }
.messages .warning{ background:rgba(245,185,66,0.15); color:#a9720c; border:1px solid rgba(245,185,66,0.3); }
.messages .error{ background:rgba(217,98,43,0.08); color:#D9622B; border:1px solid rgba(217,98,43,0.25); }

.progress-track{ height:8px; background:var(--paper); border:1px solid var(--line); border-radius:999px; overflow:hidden; }
.progress-fill{ height:100%; background: linear-gradient(90deg, var(--sky), #1b6fd6); border-radius:999px; }

.empty-state{ text-align:center; padding:40px 20px; color:var(--text-dim); font-size:14px; }

.mini-cards{ display:grid; grid-template-columns:repeat(auto-fill, minmax(260px,1fr)); gap:16px; }
.mini-card{ background:var(--white); border:1px solid var(--line); border-radius: var(--radius-sm); padding:20px; }

@media (max-width: 980px){
  .app-shell{ grid-template-columns:1fr; }
  .app-sidebar{ display:none; }
  .app-main{ padding:24px 20px; }
  .widgets{ grid-template-columns:1fr 1fr; }
  .auth-shell{ grid-template-columns:1fr; }
  .auth-visual{ display:none; }
}
