/* ===========================================================
   IECC QR Code — Premium Platform
   Light Identity (chartreuse #C0D328 + black #101010)
   =========================================================== */
:root{
  --chartreuse:#C0D328;
  --chartreuse-deep:#A8B81F;
  --chartreuse-soft:rgba(192,211,40,.14);
  --chartreuse-glow:rgba(192,211,40,.55);
  --black:#101010;
  --charcoal:#454A3B;
  --white:#FFFFFF;
  --cream:#FAFAF7;
  --cloud:#D0D0D0;
  --line:rgba(16,16,16,.08);
  --line-strong:rgba(16,16,16,.16);
  --shadow-sm:0 1px 2px rgba(16,16,16,.04),0 2px 8px rgba(16,16,16,.04);
  --shadow:0 4px 12px rgba(16,16,16,.05),0 20px 50px rgba(16,16,16,.07);
  --shadow-lg:0 20px 60px rgba(16,16,16,.12),0 40px 100px rgba(16,16,16,.08);
  --ease:cubic-bezier(.16,1,.3,1);
  --ease-out:cubic-bezier(.22,1,.36,1);
  --radius-sm:12px;
  --radius:20px;
  --radius-lg:32px;
  --radius-pill:100px;
  --container:1240px;
  --nav-h:76px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;background:var(--cream)}
body{background:var(--cream);color:var(--black);font-family:'IBM Plex Sans Arabic','Inter',system-ui,sans-serif;font-size:16px;line-height:1.7;min-height:100vh;display:flex;flex-direction:column;overflow-x:hidden}
main{flex:1}
img,svg,video{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none;transition:color .2s var(--ease)}
::selection{background:var(--chartreuse);color:var(--black)}

.container{max-width:var(--container);margin:0 auto;padding:0 5%}

/* ===== Typography ===== */
h1,h2,h3,h4{font-family:'Montserrat','IBM Plex Sans Arabic',sans-serif;font-weight:800;line-height:1.15;letter-spacing:-.02em;color:var(--black)}
h1{font-size:clamp(36px,6vw,72px);font-weight:900;letter-spacing:-.035em}
h2{font-size:clamp(28px,4vw,48px)}
h3{font-size:clamp(20px,2vw,26px)}
.muted{color:var(--charcoal)}
.tag-mini{display:inline-flex;align-items:center;gap:8px;font-size:12px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--charcoal);padding:8px 18px;background:var(--white);border:1px solid var(--line);border-radius:var(--radius-pill);box-shadow:var(--shadow-sm)}
.tag-mini::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--chartreuse);box-shadow:0 0 0 4px var(--chartreuse-soft)}

/* ===== Nav ===== */
.nav{position:sticky;top:0;z-index:100;background:rgba(250,250,247,.8);backdrop-filter:saturate(180%) blur(20px);border-bottom:1px solid var(--line)}
.nav-inner{height:var(--nav-h);display:flex;align-items:center;justify-content:space-between;max-width:var(--container);margin:0 auto;padding:0 5%}
.logo{display:flex;align-items:center;gap:12px;font-family:'Montserrat',sans-serif;font-weight:900;font-size:22px;letter-spacing:-.02em}
.logo .dot{width:10px;height:10px;border-radius:50%;background:var(--chartreuse);box-shadow:0 0 0 6px var(--chartreuse-soft)}
.logo .small{font-size:11px;letter-spacing:.18em;color:var(--charcoal);font-weight:600;text-transform:uppercase;margin-inline-start:8px;padding-inline-start:12px;border-inline-start:1px solid var(--line-strong)}
.nav-cta{background:var(--black);color:var(--white);padding:11px 26px;border-radius:var(--radius-pill);font-weight:700;font-size:14px;transition:.3s var(--ease);display:inline-flex;align-items:center;gap:8px;border:1px solid var(--black)}
.nav-cta:hover{background:var(--chartreuse);color:var(--black);border-color:var(--chartreuse);transform:translateY(-1px);box-shadow:0 8px 24px var(--chartreuse-glow)}

/* ===== Buttons ===== */
.btn{display:inline-flex;align-items:center;gap:10px;padding:16px 32px;border-radius:var(--radius-pill);font-weight:700;font-size:15px;border:1px solid transparent;cursor:pointer;transition:.3s var(--ease);font-family:inherit;line-height:1;white-space:nowrap}
.btn-primary{background:var(--chartreuse);color:var(--black);border-color:var(--chartreuse)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 14px 40px var(--chartreuse-glow);background:var(--chartreuse-deep);border-color:var(--chartreuse-deep)}
.btn-dark{background:var(--black);color:var(--white);border-color:var(--black)}
.btn-dark:hover{background:transparent;color:var(--black);transform:translateY(-2px)}
.btn-ghost{background:transparent;color:var(--black);border:1px solid var(--line-strong)}
.btn-ghost:hover{background:var(--black);color:var(--white);border-color:var(--black)}
.btn-wa{background:#25d366;color:#073;border-color:#25d366}
.btn-wa:hover{transform:translateY(-2px);box-shadow:0 14px 40px rgba(37,211,102,.4)}
.btn .arrow{transition:transform .3s var(--ease)}
.btn:hover .arrow{transform:translateX(-4px)}
[dir="rtl"] .btn:hover .arrow{transform:translateX(4px)}

/* ===== Hero ===== */
.hero{position:relative;padding:80px 0 100px;text-align:center;overflow:hidden}
.hero::before{content:"";position:absolute;top:-200px;inset-inline-start:50%;transform:translateX(50%);width:900px;height:900px;border-radius:50%;background:radial-gradient(circle,var(--chartreuse-soft) 0%,transparent 60%);pointer-events:none}
[dir="rtl"] .hero::before{transform:translateX(-50%)}
.hero-inner{position:relative;max-width:920px;margin:0 auto}
.hero h1 .hl{position:relative;display:inline-block}
.hero h1 .hl::after{content:"";position:absolute;inset:auto -6px 4px;height:18px;background:var(--chartreuse);z-index:-1;border-radius:4px}
.hero .lead{font-size:clamp(17px,2vw,22px);color:var(--charcoal);max-width:720px;margin:28px auto 40px;line-height:1.6}
.hero-cta{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.proof-bar{margin-top:60px;display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:30px;padding-top:40px;border-top:1px solid var(--line)}
.proof-bar .item{text-align:center}
.proof-bar .v{font-family:'Montserrat',sans-serif;font-size:36px;font-weight:900;letter-spacing:-.02em;line-height:1}
.proof-bar .l{font-size:13px;color:var(--charcoal);margin-top:8px;letter-spacing:.05em}

/* ===== Marquee (industries strip) ===== */
.marquee{padding:24px 0;background:var(--black);color:var(--white);overflow:hidden;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.marquee-track{display:flex;gap:60px;white-space:nowrap;animation:scroll 28s linear infinite}
.marquee-item{font-family:'Montserrat',sans-serif;font-size:18px;font-weight:800;letter-spacing:.04em;color:rgba(255,255,255,.6);display:inline-flex;align-items:center;gap:14px}
.marquee-item::after{content:"●";color:var(--chartreuse);font-size:10px}
@keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
[dir="rtl"] @keyframes scroll{from{transform:translateX(0)}to{transform:translateX(50%)}}

/* ===== Sections ===== */
section{padding:clamp(70px,9vw,120px) 0}
.section-head{text-align:center;max-width:720px;margin:0 auto 60px}
.section-head .tag-mini{margin-bottom:20px}
.section-head h2{margin-bottom:14px}
.section-head p{color:var(--charcoal);font-size:17px}

/* ===== Industries grid (premium cards) ===== */
.industries{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:18px}
.industry{position:relative;background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:32px 26px;cursor:pointer;transition:.4s var(--ease);overflow:hidden;text-align:center}
.industry::before{content:"";position:absolute;inset:auto 0 0 0;height:3px;background:var(--chartreuse);transform:scaleX(0);transform-origin:start;transition:transform .4s var(--ease)}
.industry:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:transparent}
.industry:hover::before{transform:scaleX(1)}
.industry .icon-wrap{width:74px;height:74px;border-radius:18px;display:grid;place-items:center;margin:0 auto 18px;font-size:36px;background:var(--cream);transition:.4s var(--ease)}
.industry:hover .icon-wrap{background:var(--chartreuse);transform:scale(1.05) rotate(-4deg)}
.industry h3{font-size:19px;font-weight:800;margin-bottom:6px}
.industry .ind-tag{font-size:13px;color:var(--charcoal);margin-bottom:18px;line-height:1.5;min-height:42px}
.industry .view{display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:700;color:var(--black);border-bottom:2px solid var(--chartreuse);padding-bottom:2px}

/* ===== Feature blocks (full feature set) ===== */
.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:18px}
.feature{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:32px;transition:.3s var(--ease);position:relative;overflow:hidden}
.feature:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.feature .ficon{width:54px;height:54px;border-radius:14px;background:var(--cream);display:grid;place-items:center;font-size:24px;margin-bottom:18px;border:1px solid var(--line)}
.feature.alt{background:var(--black);color:var(--white);border-color:var(--black)}
.feature.alt .ficon{background:rgba(255,255,255,.08);border-color:transparent;color:var(--chartreuse)}
.feature.alt p{color:rgba(255,255,255,.7)}
.feature.alt::after{content:"";position:absolute;top:-100px;inset-inline-end:-100px;width:240px;height:240px;border-radius:50%;background:radial-gradient(circle,var(--chartreuse-soft),transparent 70%)}
.feature h4{font-size:18px;font-weight:800;margin-bottom:10px}
.feature p{font-size:14px;color:var(--charcoal);line-height:1.6}

/* ===== How steps (vertical numbered) ===== */
.steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:18px;counter-reset:step}
.step{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:32px 26px;position:relative;transition:.3s var(--ease)}
.step:hover{border-color:var(--chartreuse);transform:translateY(-4px);box-shadow:var(--shadow)}
.step .num{counter-increment:step;width:48px;height:48px;border-radius:50%;background:var(--black);color:var(--chartreuse);font-family:'Montserrat',sans-serif;font-weight:900;font-size:18px;display:grid;place-items:center;margin-bottom:16px}
.step .num::before{content:"0" counter(step)}
.step h4{font-size:18px;font-weight:800;margin-bottom:8px}
.step p{font-size:14px;color:var(--charcoal)}

/* ===== Form ===== */
.form-section{background:var(--black);color:var(--white);position:relative;overflow:hidden}
.form-section::before{content:"";position:absolute;inset:0;background:radial-gradient(60% 50% at 80% 20%,rgba(192,211,40,.12),transparent 70%);pointer-events:none}
.form-section h2,.form-section .section-head p{color:var(--white)}
.form-section .section-head p{color:rgba(255,255,255,.65)}
.form-section .tag-mini{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.12);color:rgba(255,255,255,.85)}
.form-card{max-width:760px;margin:0 auto;background:var(--white);color:var(--black);border-radius:var(--radius-lg);padding:48px;box-shadow:var(--shadow-lg);position:relative}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-bottom:18px}
.form-row.full{grid-template-columns:1fr}
.field label{display:block;font-size:13px;font-weight:700;margin-bottom:8px;color:var(--charcoal);letter-spacing:.02em}
.field label .req{color:#dc2626;font-weight:900}
.field input,.field select,.field textarea{width:100%;background:var(--cream);border:1.5px solid transparent;border-radius:12px;padding:14px 16px;color:var(--black);font-family:inherit;font-size:15px;transition:.2s var(--ease)}
.field input::placeholder,.field textarea::placeholder{color:#9ca3af}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;background:var(--white);border-color:var(--chartreuse);box-shadow:0 0 0 4px var(--chartreuse-soft)}
.field textarea{min-height:100px;resize:vertical;line-height:1.6}
.form-card .btn{width:100%;justify-content:center;font-size:16px;padding:18px;margin-top:6px}
.terms{text-align:center;color:var(--charcoal);font-size:12px;margin-top:14px;line-height:1.6}

/* ===== Template preview ===== */
.tpl-hero{display:grid;grid-template-columns:1.1fr 1fr;gap:60px;align-items:center;padding:60px 0 80px}
.tpl-head .meta{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:24px}
.tpl-head .meta .tag{background:var(--white);border:1px solid var(--line);padding:7px 16px;border-radius:var(--radius-pill);font-size:12px;font-weight:600;color:var(--charcoal)}
.tpl-head h1{font-size:clamp(32px,4.5vw,52px);margin-bottom:18px}
.tpl-head .sub{font-size:17px;color:var(--charcoal);margin-bottom:28px}
.tpl-head .actions{display:flex;gap:12px;flex-wrap:wrap}
.tpl-metrics{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:36px}
.tpl-metrics .m{background:var(--white);border:1px solid var(--line);border-radius:14px;padding:16px;text-align:center}
.tpl-metrics .v{font-family:'Montserrat',sans-serif;font-size:24px;font-weight:900;color:var(--black)}
.tpl-metrics .l{font-size:11px;color:var(--charcoal);margin-top:4px}

/* Real phone with iframe */
.phone-real{position:relative;background:var(--black);border-radius:42px;padding:12px;width:320px;max-width:100%;height:660px;margin:0 auto;box-shadow:0 30px 80px rgba(16,16,16,.28),0 0 0 1px rgba(16,16,16,.05)}
.phone-real .notch{position:absolute;top:12px;inset-inline:50%;transform:translateX(-50%);width:92px;height:24px;background:var(--black);border-radius:0 0 14px 14px;z-index:2}
.phone-real iframe{width:100%;height:100%;border:0;border-radius:30px;background:#fff;display:block}

/* Legacy phone mockup (kept for backwards compat) */
.phone{position:relative;background:var(--black);border-radius:42px;padding:14px;width:300px;max-width:100%;aspect-ratio:9/19.5;margin:0 auto;box-shadow:0 30px 80px rgba(16,16,16,.25),0 0 0 1px rgba(16,16,16,.05)}
.phone::before{content:"";position:absolute;top:14px;inset-inline:50%;transform:translateX(-50%);width:90px;height:24px;background:var(--black);border-radius:0 0 14px 14px;z-index:2}
.phone-screen{background:var(--white);border-radius:30px;overflow:hidden;height:100%;display:flex;flex-direction:column;position:relative}
.phone-header{padding:36px 16px 16px;text-align:center;color:var(--white);position:relative}
.phone-header .logo-mini{width:48px;height:48px;border-radius:14px;background:rgba(255,255,255,.95);color:var(--black);display:grid;place-items:center;font-size:22px;margin:0 auto 8px}
.phone-header .name{font-weight:900;font-size:15px;line-height:1.2}
.phone-header .place{font-size:11px;opacity:.85;margin-top:2px}
.phone-body{flex:1;overflow:hidden;padding:12px}
.phone-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px}
.phone-grid .ph{aspect-ratio:1;border-radius:10px;display:grid;place-items:center;font-size:24px;color:rgba(255,255,255,.85)}
.phone-grid .ph.wide{grid-column:span 2;aspect-ratio:2.2/1}
.phone-actions{padding:10px 12px;border-top:1px solid #eee;display:flex;justify-content:space-around;font-size:18px;color:var(--charcoal)}

/* Themed gradient cells */
.theme-warm .ph{background:linear-gradient(135deg,#FF6B35,#F7931E)}
.theme-warm .ph:nth-child(odd){background:linear-gradient(135deg,#E55A2B,#FFA94D)}
.theme-cozy .ph{background:linear-gradient(135deg,#8B5E3C,#D4A574)}
.theme-cozy .ph:nth-child(odd){background:linear-gradient(135deg,#6B4423,#B88A5E)}
.theme-runway .ph{background:linear-gradient(135deg,#1a1a2e,#16213e)}
.theme-runway .ph:nth-child(odd){background:linear-gradient(135deg,#2c2c44,#3d3d5c)}
.theme-pink .ph{background:linear-gradient(135deg,#D63384,#F77AB6)}
.theme-pink .ph:nth-child(odd){background:linear-gradient(135deg,#B82B71,#E863A0)}
.theme-bold .ph{background:linear-gradient(135deg,#101010,#2a2a2a);color:var(--chartreuse)}
.theme-bold .ph:nth-child(odd){background:linear-gradient(135deg,#1a1a1a,#404040)}
.theme-clinical .ph{background:linear-gradient(135deg,#0EA5E9,#10B981)}
.theme-clinical .ph:nth-child(odd){background:linear-gradient(135deg,#0284c7,#059669)}
.theme-sweet .ph{background:linear-gradient(135deg,#D97706,#FCD34D);color:#7c2d12}
.theme-sweet .ph:nth-child(odd){background:linear-gradient(135deg,#B45309,#F59E0B)}
.theme-general .ph{background:linear-gradient(135deg,#6366F1,#A78BFA)}
.theme-general .ph:nth-child(odd){background:linear-gradient(135deg,#4F46E5,#8B5CF6)}

.tpl-sections{padding:60px 0}
.tpl-sections h2{text-align:center;margin-bottom:36px;font-size:32px}
.sect-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:14px}
.sect{background:var(--white);border:1px solid var(--line);border-radius:14px;padding:22px;text-align:center;transition:.3s var(--ease)}
.sect:hover{border-color:var(--chartreuse);transform:translateY(-3px)}
.sect .ico{font-size:24px;margin-bottom:10px}
.sect .label{font-size:14px;font-weight:700}

/* Other industries strip */
.other-inds{padding:80px 0;background:var(--white);border-top:1px solid var(--line)}

/* ===== Thanks ===== */
.thanks{max-width:580px;margin:60px auto;text-align:center;padding:60px 30px;background:var(--white);border-radius:var(--radius-lg);box-shadow:var(--shadow);border:1px solid var(--line)}
.thanks .check{width:96px;height:96px;border-radius:50%;background:var(--chartreuse);display:grid;place-items:center;margin:0 auto 28px;font-size:52px;color:var(--black);box-shadow:0 0 0 12px var(--chartreuse-soft)}
.thanks h1{font-size:36px;margin-bottom:16px;letter-spacing:-.02em}
.thanks p{color:var(--charcoal);margin-bottom:32px;font-size:16px}

/* ===== Footer ===== */
footer{padding:60px 0 40px;background:var(--black);color:rgba(255,255,255,.7);margin-top:60px;border-top:4px solid var(--chartreuse)}
footer .ft-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:60px;margin-bottom:50px}
footer .brand-block .logo{color:var(--white);margin-bottom:16px}
footer .brand-block .logo .small{color:rgba(255,255,255,.5);border-color:rgba(255,255,255,.18)}
footer .brand-block p{font-size:14px;line-height:1.7;max-width:380px}
footer .col h5{color:var(--white);font-size:13px;font-weight:800;text-transform:uppercase;letter-spacing:.1em;margin-bottom:18px}
footer .col a{display:block;font-size:14px;padding:6px 0;color:rgba(255,255,255,.65);transition:color .2s var(--ease)}
footer .col a:hover{color:var(--chartreuse)}
footer .ft-bottom{border-top:1px solid rgba(255,255,255,.1);padding-top:24px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px;font-size:13px}
footer .powered{display:inline-flex;align-items:center;gap:10px;background:rgba(192,211,40,.1);border:1px solid rgba(192,211,40,.3);padding:8px 16px;border-radius:var(--radius-pill);color:var(--chartreuse);font-weight:700;font-size:13px;letter-spacing:.05em}
footer .powered .dot{width:8px;height:8px;border-radius:50%;background:var(--chartreuse);box-shadow:0 0 12px var(--chartreuse-glow)}

/* ===== Admin ===== */
.admin-shell{padding:40px 0}
.admin-stat{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:30px}
.stat{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:24px;position:relative;overflow:hidden}
.stat .v{font-family:'Montserrat',sans-serif;font-size:34px;font-weight:900;letter-spacing:-.02em}
.stat .l{color:var(--charcoal);font-size:13px;margin-top:4px;font-weight:600}
.stat::before{content:"";position:absolute;inset-inline-start:0;top:0;bottom:0;width:4px;background:var(--chartreuse)}
table{width:100%;border-collapse:separate;border-spacing:0;background:var(--white);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
th,td{padding:14px 16px;text-align:start;border-bottom:1px solid var(--line);font-size:14px}
th{background:var(--cream);color:var(--charcoal);font-weight:700;font-size:11px;text-transform:uppercase;letter-spacing:.08em}
tr:last-child td{border-bottom:none}
tbody tr:hover{background:var(--cream)}
.pill{display:inline-block;padding:4px 12px;border-radius:99px;font-size:11px;font-weight:700;letter-spacing:.04em}
.pill.new{background:rgba(14,165,233,.12);color:#0369a1}
.pill.contacted{background:rgba(245,158,11,.12);color:#b45309}
.pill.done{background:var(--chartreuse-soft);color:var(--charcoal)}
.toolbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;gap:10px;flex-wrap:wrap}
.toolbar input,.toolbar select{background:var(--white);border:1px solid var(--line);color:var(--black);padding:10px 14px;border-radius:10px;font-family:inherit;font-size:14px}
.editor{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:32px;margin-bottom:30px;box-shadow:var(--shadow-sm)}
.editor h3{margin-bottom:20px;font-size:22px}
.flash{background:var(--chartreuse-soft);border:1px solid var(--chartreuse);color:var(--black);padding:14px 20px;border-radius:12px;margin-bottom:20px;font-weight:600}
.detail{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px 28px;margin-bottom:22px;padding:20px;background:var(--cream);border-radius:14px;font-size:14px}
.detail div b{color:var(--charcoal);font-weight:700;display:block;font-size:11px;margin-bottom:3px;text-transform:uppercase;letter-spacing:.05em}
.wa-deeplink{background:#25d366;color:#053a1d;padding:14px 24px;border-radius:var(--radius-pill);font-weight:700;display:inline-flex;gap:8px;align-items:center;text-decoration:none;margin-inline-end:8px;border:1px solid #25d366;transition:.3s var(--ease);font-size:14px}
.wa-deeplink:hover{transform:translateY(-2px);box-shadow:0 10px 28px rgba(37,211,102,.4)}
.row-actions a{font-size:12px;color:var(--charcoal);margin-inline-end:10px;font-weight:600}
.row-actions a:hover{color:var(--black)}
.row-actions a.danger:hover{color:#dc2626}

/* Auth */
.auth-wrap{min-height:80vh;display:grid;place-items:center;padding:40px 0}
.auth-card{background:var(--white);border:1px solid var(--line);border-radius:var(--radius-lg);padding:48px;width:100%;max-width:440px;box-shadow:var(--shadow)}
.auth-card h2{text-align:center;margin-bottom:8px}
.auth-card p{text-align:center;color:var(--charcoal);margin-bottom:28px;font-size:14px}

/* Responsive */
@media(max-width:880px){
  .tpl-hero{grid-template-columns:1fr;gap:40px;text-align:center}
  .tpl-head .actions,.tpl-head .meta{justify-content:center}
  footer .ft-grid{grid-template-columns:1fr;gap:36px}
}
@media(max-width:720px){
  .form-row{grid-template-columns:1fr}
  .form-card{padding:32px 24px}
  .tpl-metrics{grid-template-columns:1fr 1fr}
  .logo .small{display:none}
  .nav-cta{padding:9px 18px;font-size:13px}
  footer .ft-bottom{justify-content:center;text-align:center}
}

/* Reveal animation */
.reveal{opacity:0;transform:translateY(20px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal.in{opacity:1;transform:none}
