@import url('https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,500;0,9..40,700;0,9..40,800;0,9..40,900;1,9..40,400&family=Outfit:wght@400;600;700;800;900&display=swap');

:root{
  --font-display:'Outfit',system-ui,sans-serif;
  --font-body:'DM Sans',system-ui,sans-serif;
  --bg:#060e1a;--bg-soft:#0a1628;--bg-card:#0d1b30;--bg-card-2:#111f3a;
  --bg-elevated:linear-gradient(168deg,rgba(16,30,56,.92),rgba(10,20,40,.96));
  --line:rgba(148,163,184,.10);--line-strong:rgba(148,163,184,.18);
  --text:#dce6f2;--muted:#7e96b4;--heading:#f1f6fc;
  --primary:#4F8EF7;--primary-strong:#3672db;--primary-glow:rgba(79,142,247,.18);
  --success:#34D399;--success-soft:rgba(52,211,153,.12);
  --warning:#FBBF24;--warning-soft:rgba(251,191,36,.12);
  --danger:#F87171;--danger-soft:rgba(248,113,113,.12);
  --accent:#A78BFA;--accent-soft:rgba(167,139,250,.12);
  --shadow-sm:0 2px 8px rgba(0,0,0,.18);--shadow:0 8px 32px rgba(0,0,0,.22);--shadow-lg:0 20px 60px rgba(0,0,0,.28);
  --glass:rgba(255,255,255,.04);--glass-border:rgba(255,255,255,.08);
  --radius:20px;--radius-sm:14px;--radius-xs:10px;
  --content-bg:linear-gradient(180deg,#070f1e,#060c18);
  --transition:all .2s cubic-bezier(.4,0,.2,1);
}
html[data-theme="light"]{
  --bg:#F0F4FA;--bg-soft:#F7F9FE;--bg-card:#FFFFFF;--bg-card-2:#FAFBFF;
  --bg-elevated:linear-gradient(168deg,rgba(255,255,255,.96),rgba(248,250,255,.98));
  --line:rgba(15,23,42,.06);--line-strong:rgba(15,23,42,.10);
  --text:#1e293b;--muted:#64748b;--heading:#0f172a;
  --primary:#3B6FE0;--primary-strong:#2b5bc4;--primary-glow:rgba(59,111,224,.10);
  --success:#16A34A;--success-soft:rgba(22,163,74,.08);
  --warning:#D97706;--warning-soft:rgba(217,119,6,.08);
  --danger:#DC2626;--danger-soft:rgba(220,38,38,.08);
  --accent:#7C3AED;--accent-soft:rgba(124,58,237,.08);
  --shadow-sm:0 1px 4px rgba(15,23,42,.06);--shadow:0 4px 20px rgba(15,23,42,.08);--shadow-lg:0 12px 40px rgba(15,23,42,.10);
  --glass:rgba(255,255,255,.72);--glass-border:rgba(15,23,42,.06);
  --content-bg:linear-gradient(180deg,#EFF3FA,#E8ECF4);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
html,body{font-family:var(--font-body);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased}
a{text-decoration:none;color:inherit}img{max-width:100%;display:block}
button,input,select,textarea{font:inherit}body{min-height:100svh}
::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:rgba(148,163,184,.18);border-radius:99px}
@keyframes fadeUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}

/* PUBLIC / LOGIN */
.public-body{position:relative;min-height:100svh;background:radial-gradient(circle at top left,rgba(79,142,247,.16),transparent 28%),radial-gradient(circle at 80% 20%,rgba(52,211,153,.14),transparent 24%),linear-gradient(180deg,#050b16,#081325 55%,#07111e);color:#fff;overflow-x:hidden}
.public-bg-orb{position:fixed;border-radius:999px;filter:blur(40px);opacity:.45;pointer-events:none;z-index:0}
.public-bg-orb.orb-a{width:340px;height:340px;left:-100px;top:-120px;background:radial-gradient(circle,#1d4ed8,transparent 68%)}
.public-bg-orb.orb-b{width:300px;height:300px;right:-80px;bottom:-90px;background:radial-gradient(circle,#10b981,transparent 70%)}
.public-bg-grid{position:fixed;inset:0;background-image:linear-gradient(rgba(255,255,255,.02) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.02) 1px,transparent 1px);background-size:36px 36px;mask-image:linear-gradient(180deg,rgba(0,0,0,.55),transparent 90%);pointer-events:none;z-index:0}
.public-flash-wrap{position:fixed;left:50%;top:16px;transform:translateX(-50%);z-index:60;width:min(92vw,640px)}
.landing-screen,.auth-screen{min-height:100svh}
.public-shell{position:relative;z-index:1;min-height:100svh;display:flex;align-items:center;justify-content:center;padding:34px 20px}
.public-grid{width:min(1200px,100%);display:grid;grid-template-columns:1.06fr .94fr;gap:22px;align-items:stretch}
.landing-grid{grid-template-columns:1.08fr .92fr}
.brand-pill{display:inline-flex;align-items:center;gap:12px;padding:12px 18px;border-radius:999px;background:rgba(9,18,36,.74);border:1px solid rgba(79,142,247,.28);backdrop-filter:blur(14px);box-shadow:0 8px 30px rgba(0,0,0,.16)}
.brand-mark-img{width:26px;height:26px;object-fit:contain;filter:drop-shadow(0 0 12px rgba(79,142,247,.32))}
.brand-pill span{font-family:var(--font-display);font-weight:800;font-size:1rem;color:#fff}
.marketing-panel,.showcase-card,.auth-panel{position:relative;background:linear-gradient(180deg,rgba(8,18,35,.9),rgba(6,14,28,.86));border:1px solid rgba(148,163,184,.12);box-shadow:0 24px 80px rgba(0,0,0,.30);backdrop-filter:blur(18px)}
.marketing-panel{border-radius:30px;padding:34px;display:flex;flex-direction:column;justify-content:center;overflow:hidden}
.marketing-panel::before,.showcase-card::before,.auth-panel::before{content:"";position:absolute;inset:auto auto 0 0;width:100%;height:1px;background:linear-gradient(90deg,transparent,rgba(79,142,247,.45),rgba(52,211,153,.45),transparent)}
.hero-kicker{display:inline-flex;width:max-content;margin-top:20px;margin-bottom:10px;font-weight:800;letter-spacing:.02em;color:#9be7c9;background:rgba(16,185,129,.10);border:1px solid rgba(16,185,129,.18);padding:8px 12px;border-radius:999px}
.marketing-panel h1{font-family:var(--font-display);font-size:clamp(2.2rem,4vw,4.4rem);line-height:1.03;letter-spacing:-.04em;color:#fff;font-weight:900;max-width:12ch;margin:6px 0 14px}
.marketing-panel p{color:#c5d4e6;font-size:1.02rem;line-height:1.7;max-width:60ch}
.landing-actions{display:flex;gap:12px;flex-wrap:wrap;margin:24px 0 18px}
.feature-chip-row{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:18px}
.feature-chip{display:inline-flex;align-items:center;padding:9px 13px;border-radius:999px;background:rgba(79,142,247,.10);border:1px solid rgba(79,142,247,.18);color:#dbeafe;font-weight:700;font-size:.88rem}
.landing-info-grid.clean-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:4px}
.landing-info-box{padding:18px;border-radius:20px;background:rgba(255,255,255,.03);border:1px solid rgba(148,163,184,.12)}
.landing-info-box strong{display:block;color:#fff;margin-bottom:8px;font-family:var(--font-display);font-size:1rem}
.landing-info-box span{display:block;color:#b5c6db;line-height:1.55;font-size:.95rem}
.showcase-panel{display:flex}
.showcase-card{border-radius:30px;padding:28px;display:flex;flex-direction:column;width:100%}
.showcase-card-head{display:flex;justify-content:space-between;gap:12px;align-items:flex-start;margin-bottom:18px}
.showcase-label{display:inline-block;color:#9cc5ff;font-weight:800;text-transform:uppercase;letter-spacing:.07em;font-size:.72rem;margin-bottom:8px}
.showcase-card-head h2{font-family:var(--font-display);font-size:1.65rem;line-height:1.1;color:#fff;margin:0;letter-spacing:-.02em}
.showcase-badge{display:inline-flex;align-items:center;padding:8px 12px;border-radius:999px;background:rgba(16,185,129,.12);border:1px solid rgba(16,185,129,.18);font-weight:800;color:#a7f3d0}
.showcase-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:16px}
.showcase-stat{padding:16px;border-radius:20px;background:rgba(255,255,255,.03);border:1px solid rgba(148,163,184,.12)}
.showcase-stat small{display:block;color:#7dd3fc;font-size:.82rem;text-transform:uppercase;letter-spacing:.05em;margin-bottom:6px}
.showcase-stat strong{display:block;font-family:var(--font-display);font-size:1.32rem;color:#fff;margin-bottom:4px}
.showcase-stat span{font-size:.84rem;font-weight:700}
.positive{color:#6ee7b7}.muted-lite{color:#94a3b8}
.mini-chart-card{position:relative;height:220px;border-radius:24px;background:linear-gradient(180deg,rgba(15,23,42,.92),rgba(8,15,30,.95));border:1px solid rgba(148,163,184,.10);overflow:hidden;margin:4px 0 18px}
.mini-bars{position:absolute;left:24px;right:24px;bottom:22px;height:136px;display:flex;gap:14px;align-items:flex-end}
.mini-bars span{flex:1;border-radius:14px 14px 6px 6px;background:linear-gradient(180deg,rgba(59,130,246,.25),rgba(16,185,129,.5));box-shadow:0 0 14px rgba(16,185,129,.08)}
.mini-chart-line{position:absolute;left:20px;right:20px;bottom:58px;height:95px;border-bottom:2px solid transparent}
.mini-chart-line::before{content:"";position:absolute;left:0;right:0;top:16px;height:3px;border-radius:999px;background:linear-gradient(90deg,#2563eb 0%,#38bdf8 18%,#34d399 42%,#38bdf8 63%,#10b981 100%);transform:skewY(-12deg);box-shadow:0 0 22px rgba(52,211,153,.38)}
.mini-chart-line::after{content:"";position:absolute;right:-2px;top:-2px;width:12px;height:12px;border-radius:999px;background:#6ee7b7;box-shadow:0 0 20px rgba(110,231,183,.6)}
.showcase-list{display:grid;gap:12px}
.showcase-list-item{padding:16px 18px;border-radius:18px;background:rgba(255,255,255,.03);border:1px solid rgba(148,163,184,.10)}
.showcase-list-item strong{display:block;color:#fff;font-family:var(--font-display);font-size:1rem;margin-bottom:6px}
.showcase-list-item span{display:block;color:#aec0d5;line-height:1.55;font-size:.93rem}
.auth-shell .public-grid{grid-template-columns:1fr 1fr;align-items:center}
.auth-copy-panel{padding:32px;min-height:100%}
.feature-list-clean{display:grid;gap:12px;margin-top:22px}
.feature-list-item{display:flex;align-items:flex-start;gap:12px;color:#dbe7f5;font-weight:600;line-height:1.55}
.feature-list-item span{width:11px;height:11px;border-radius:999px;background:linear-gradient(180deg,#34d399,#60a5fa);box-shadow:0 0 0 5px rgba(79,142,247,.10);margin-top:7px;flex-shrink:0}
.auth-panel{border-radius:28px;padding:28px 28px 24px}
.auth-panel-top{margin-bottom:18px}
.auth-panel-top h2{font-family:var(--font-display);font-size:2rem;line-height:1.05;color:#fff;margin:0 0 8px;letter-spacing:-.03em}
.auth-panel-top p{color:#b6c8dc;line-height:1.6}
.auth-form-clean{gap:16px}
.auth-actions-clean{justify-content:flex-start;margin-top:4px}
.auth-footer-note{margin-top:18px;padding-top:16px;border-top:1px solid rgba(148,163,184,.10);color:#8fa6c1;font-size:.92rem}
.remember-line-clean{color:#cfe0f4;padding-left:2px}
.register-panel-clean{padding-bottom:28px}
.center-card-wrap{min-height:100svh;display:grid;place-items:center;padding:24px;background:radial-gradient(circle at top,#13284a 0%,#050d1a 70%)}
.center-card{max-width:520px;padding:32px;border-radius:24px;background:rgba(7,18,42,.72);border:1px solid rgba(255,255,255,.10);text-align:center;color:#fff}
.center-card h1{font-family:var(--font-display);font-size:3.5rem;margin:0 0 12px;font-weight:900}
/* BUTTONS / FORMS */
.button,.btn-soft{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:48px;padding:0 20px;border-radius:14px;border:1px solid transparent;font-family:var(--font-display);font-weight:700;font-size:.94rem;cursor:pointer;transition:var(--transition)}
.button-primary,.btn-primary,.btn-soft{background:linear-gradient(180deg,var(--primary),var(--primary-strong));color:#fff;border-color:rgba(255,255,255,.06);box-shadow:0 4px 16px rgba(79,142,247,.22)}
.button-secondary{background:var(--glass);color:var(--text);border-color:var(--line-strong)}
html[data-theme="light"] .button-secondary{background:#fff;color:#0f172a;border-color:rgba(15,23,42,.08)}
.button:hover,.btn-soft:hover{transform:translateY(-1px);box-shadow:0 8px 24px rgba(79,142,247,.28)}
.button-block{width:100%}
.modern-form{display:grid;gap:14px}
.field label,.form-label{display:block;font-weight:600;margin-bottom:6px;color:var(--muted);font-size:.85rem;letter-spacing:.02em;text-transform:uppercase}
.input,.form-control,.form-select,textarea{width:100%;min-height:46px;border-radius:var(--radius-xs);border:1px solid var(--line-strong);background:var(--bg-card-2);color:var(--text);padding:11px 14px;outline:none;font-size:.96rem;transition:var(--transition)}
.input:focus,.form-control:focus,.form-select:focus,textarea:focus{border-color:rgba(79,142,247,.4);box-shadow:0 0 0 3px rgba(79,142,247,.08)}
.password-wrap{position:relative}.password-wrap .password-toggle{position:absolute;right:10px;top:50%;transform:translateY(-50%);border:0;border-radius:10px;padding:7px 10px;background:var(--primary-glow);color:var(--primary);font-weight:700;font-size:.85rem;cursor:pointer}
.checkbox-card{display:flex;gap:12px;align-items:center;padding:12px 14px;border-radius:14px;background:var(--glass);border:1px solid var(--line)}
.field-grid{display:grid;gap:14px}.field-grid.two-col{grid-template-columns:repeat(2,1fr)}
.form-light .field label{color:#fff}.file-input{padding-top:9px}

/* APP SHELL */
.app-body{background:var(--content-bg)}.app-shell{min-height:100svh}
.app-sidebar{position:fixed;left:0;top:0;bottom:0;width:260px;padding:18px 12px 12px;background:var(--bg-elevated);border-right:1px solid var(--glass-border);z-index:45;display:flex;flex-direction:column;gap:12px;overflow-y:auto;transition:transform .25s cubic-bezier(.4,0,.2,1)}
html[data-theme="light"] .app-sidebar{border-right-color:rgba(15,23,42,.06)}
.sidebar-brand-row{display:flex;align-items:center;justify-content:space-between;gap:10px}
.sidebar-brand{display:flex;align-items:center;gap:10px}
.brand-badge{width:40px;height:40px;border-radius:12px;display:grid;place-items:center;background:linear-gradient(135deg,#2563eb,#10b981);color:#fff;font-family:var(--font-display);font-size:.88rem;font-weight:900;box-shadow:0 8px 22px rgba(37,99,235,.28)}
.brand-logo-img{width:42px;height:42px;object-fit:contain;filter:drop-shadow(0 0 14px rgba(37,99,235,.22))}
.sidebar-brand strong{display:block;font-family:var(--font-display);font-size:.96rem;color:var(--heading);font-weight:800}
.sidebar-brand small{display:block;color:var(--muted);font-size:.76rem;margin-top:1px}
.sidebar-close{border:0;background:transparent;color:var(--text);font-size:1.6rem;line-height:1;cursor:pointer;padding:4px}
.sidebar-profile{display:flex;gap:10px;align-items:center;padding:12px;border-radius:14px;background:var(--glass);border:1px solid var(--glass-border)}
.profile-avatar,.header-avatar,.profile-photo-placeholder,.admin-avatar.placeholder{width:38px;height:38px;border-radius:10px;display:grid;place-items:center;background:linear-gradient(180deg,#334155,#1e293b);font-family:var(--font-display);font-weight:800;color:#fff;font-size:.95rem}
.profile-avatar-img,.profile-photo-large,.header-avatar-img,.admin-avatar{width:38px;height:38px;border-radius:10px;object-fit:cover;border:1px solid var(--glass-border)}
.profile-meta strong{display:block;color:var(--heading);font-size:.88rem;font-family:var(--font-display)}
.profile-meta span{display:block;color:var(--muted);font-size:.76rem;margin-top:2px}
.sidebar-nav{display:grid;gap:3px;overflow:auto;flex:1;padding-right:4px}
.nav-item{display:flex;align-items:center;gap:10px;min-height:40px;padding:0 12px;border-radius:10px;color:var(--muted);font-weight:600;font-size:.88rem;border:1px solid transparent;transition:var(--transition)}
.nav-item:hover{background:var(--primary-glow);color:var(--heading);border-color:rgba(79,142,247,.08)}
.nav-item.active{background:var(--primary-glow);border-color:rgba(79,142,247,.16);color:var(--primary);font-weight:700}
html[data-theme="light"] .nav-item.active{color:var(--primary-strong)}
.nav-icon{width:18px;height:18px;flex-shrink:0;opacity:.65}
.nav-item.active .nav-icon{opacity:1}
.nav-item span{display:none}
.sidebar-actions{margin-top:auto;display:grid;gap:5px}
/* Mobile top action buttons - hidden on desktop */
.mobile-top-actions{display:none;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:10px}
.mobile-top-btn{display:flex;align-items:center;justify-content:center;gap:6px;min-height:40px;border-radius:12px;font-family:var(--font-display);font-weight:700;font-size:.88rem;transition:var(--transition)}
.mobile-top-btn.primary{background:linear-gradient(180deg,var(--primary),var(--primary-strong));color:#fff;box-shadow:0 4px 14px rgba(79,142,247,.22)}
.mobile-top-btn.success{background:var(--success-soft);color:var(--success);border:1px solid rgba(52,211,153,.18)}
.sidebar-mini-button{width:100%;min-height:38px;border-radius:10px;border:1px solid var(--line-strong);background:var(--glass);color:var(--text);font-weight:700;font-size:.84rem;cursor:pointer;transition:var(--transition)}
.sidebar-mini-button:hover{background:var(--primary-glow);border-color:rgba(79,142,247,.12)}
.sidebar-mini-button.danger{border-color:rgba(248,113,113,.16);color:var(--danger);background:var(--danger-soft)}
html[data-theme="light"] .sidebar-mini-button.danger{color:#b91c1c}

/* MAIN */
.app-main{margin-left:260px;padding:20px 22px 30px;animation:fadeIn .3s ease}
.app-header{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:18px}
.app-header-left{display:flex;align-items:center;gap:12px}
.menu-toggle-modern{width:42px;height:42px;border-radius:12px;border:1px solid var(--line);background:var(--bg-card);display:grid;place-items:center;gap:3px;cursor:pointer;box-shadow:var(--shadow-sm);transition:var(--transition)}
.menu-toggle-modern:hover{border-color:var(--primary-glow);background:var(--primary-glow)}
.menu-toggle-modern span{display:block;width:18px;height:2px;background:var(--heading);border-radius:99px}
html[data-theme="light"] .menu-toggle-modern{background:#fff}
.header-brand-mobile{display:none;font-family:var(--font-display);font-weight:800;font-size:1.02rem;color:var(--heading)}
.header-title-wrap{display:grid;gap:2px}
.page-title{margin:0;font-family:var(--font-display);font-size:clamp(1.5rem,2.2vw,2.2rem);color:var(--heading);font-weight:900;letter-spacing:-.03em}
.page-desc{margin:0;color:var(--muted);max-width:56ch;font-size:.88rem}
.app-header-right{display:flex;gap:8px;align-items:center}
.desktop-quick-actions{display:flex;gap:8px}
.header-profile-link{display:block;border-radius:12px;overflow:hidden}
.header-avatar,.header-avatar-img{width:38px;height:38px;border-radius:12px}
.ghost-accent{background:var(--glass)!important;color:var(--text)!important;border-color:var(--line-strong)!important;box-shadow:none!important}

/* FLASH */
.flash-stack{display:grid;gap:8px;margin-bottom:14px;animation:fadeUp .3s ease}
.flash-alert{padding:12px 16px;border-radius:14px;font-weight:600;font-size:.9rem;border:1px solid transparent}
.flash-alert.success{background:var(--success-soft);color:var(--success);border-color:rgba(52,211,153,.16)}
.flash-alert.info{background:var(--primary-glow);color:var(--primary);border-color:rgba(79,142,247,.16)}
.flash-alert.warning{background:var(--warning-soft);color:var(--warning);border-color:rgba(251,191,36,.16)}
.flash-alert.danger{background:var(--danger-soft);color:var(--danger);border-color:rgba(248,113,113,.16)}
html[data-theme="light"] .flash-alert.success{background:#dcfce7;color:#166534;border-color:#bbf7d0}
html[data-theme="light"] .flash-alert.info{background:#dbeafe;color:#1d4ed8;border-color:#bfdbfe}
html[data-theme="light"] .flash-alert.warning{background:#fef3c7;color:#92400e;border-color:#fde68a}
html[data-theme="light"] .flash-alert.danger{background:#fee2e2;color:#b91c1c;border-color:#fecaca}

/* CARDS & PANELS */
.panel-card,.kpi-card{background:var(--bg-card);border:1px solid var(--line);box-shadow:var(--shadow);border-radius:var(--radius);padding:16px;position:relative;animation:fadeUp .35s ease both}
.panel-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:12px}
.panel-head.slim-head{align-items:center}
.panel-title{font-family:var(--font-display);font-size:1.2rem;font-weight:800;color:var(--heading);margin-bottom:2px;letter-spacing:-.01em}
.panel-sub{color:var(--muted);font-size:.85rem}
.elevated-card{background:var(--bg-elevated);border:1px solid var(--glass-border);box-shadow:var(--shadow)}
html[data-theme="light"] .elevated-card{background:linear-gradient(168deg,rgba(255,255,255,.98),rgba(248,250,255,.95));border-color:rgba(15,23,42,.06)}

/* KPI */
.kpi-label{color:var(--muted);font-weight:700;margin-bottom:5px;font-size:.78rem;text-transform:uppercase;letter-spacing:.05em}
.kpi-value{font-family:var(--font-display);font-weight:900;font-size:1.7rem;line-height:1.1;color:var(--heading);letter-spacing:-.02em}
.kpi-value.small{font-size:1.3rem}.kpi-hint{font-size:.85rem;color:var(--muted);margin-top:3px}
.kpi-positive{color:var(--success)}.kpi-negative{color:var(--danger)}.kpi-pending{color:var(--warning)}
.kpi-highlight{border-color:rgba(79,142,247,.18);background:linear-gradient(180deg,rgba(79,142,247,.06),var(--bg-card))}
.kpi-card.compact{padding:12px 14px}
.kpi-top{display:flex;align-items:center;gap:8px;color:var(--muted);font-weight:700;margin-bottom:8px;font-size:.82rem}
.kpi-icon{width:30px;height:30px;border-radius:8px;display:grid;place-items:center;background:var(--glass)}
.kpi-card.success{border-color:rgba(52,211,153,.14)}.kpi-card.warning{border-color:rgba(251,191,36,.14)}
.kpi-card.info{border-color:rgba(79,142,247,.14)}.kpi-card.accent{border-color:rgba(167,139,250,.14)}

/* DASHBOARD */
.dashboard-v2-grid{display:grid;gap:14px}
.kpi-row-2026{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
.kpi-focus{padding:16px;min-height:100px}
.kpi-focus .kpi-label{font-size:.74rem}.kpi-focus .kpi-value{font-size:1.7rem}
.main-dashboard-columns{display:grid;grid-template-columns:1.5fr .55fr;gap:14px}
.left-dashboard-stack,.right-dashboard-stack{display:grid;gap:0;align-content:start}
.chart-master-panel{min-height:360px}
.double-panel-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.right-dashboard-stack{align-self:start}
.quick-action-stack{display:grid;gap:6px;margin-top:10px}
.quick-action-premium{display:flex;align-items:center;justify-content:center;min-height:40px;padding:0 12px;border-radius:10px;background:var(--bg-card-2);border:1px solid var(--line-strong);font-family:var(--font-display);font-weight:700;font-size:.86rem;color:var(--text);transition:var(--transition)}
.quick-action-premium:hover{transform:translateY(-1px);border-color:rgba(79,142,247,.18);box-shadow:var(--shadow-sm)}
.quick-action-premium.primary{background:linear-gradient(180deg,var(--primary),var(--primary-strong));color:#fff;border-color:transparent;box-shadow:0 4px 16px rgba(79,142,247,.22)}
.quick-action-premium.secondary{background:var(--success-soft);color:var(--success);border-color:rgba(52,211,153,.14)}
.dashboard-mini-kpis{display:grid;gap:6px}
.mini-kpi-box{padding:10px 12px;border-radius:12px;background:var(--glass);border:1px solid var(--line)}
.mini-kpi-box small{display:block;color:var(--muted);margin-bottom:3px;font-size:.78rem}
.mini-kpi-box strong{font-family:var(--font-display);font-size:1.05rem}

/* BANK */
.bank-logo-img{width:36px;height:36px;border-radius:10px;object-fit:cover;box-shadow:var(--shadow-sm)}
.bank-logo-img.large{width:46px;height:46px;border-radius:12px}
.bank-badge{display:flex;align-items:center;gap:10px}
.bank-badge strong{display:block;color:var(--heading);font-size:.88rem;font-family:var(--font-display)}
.bank-badge small,.table-sub-copy,.amount-sub{display:block;color:var(--muted);font-size:.8rem;margin-top:1px}
.amount-main{display:block;font-family:var(--font-display);font-weight:800;color:var(--heading)}
.modern-bank-row{padding:10px 12px;border-radius:12px;background:var(--glass);border:1px solid var(--line);transition:var(--transition)}
.modern-bank-row:hover{border-color:rgba(79,142,247,.12)}
.modern-bank-row .bank-mini-values{text-align:right}
.chart-box{position:relative;width:100%}
.chart-compact{height:200px}.chart-small-mobile{height:280px}.chart-large{height:300px}
.mobile-list-cards{display:grid;gap:8px}
.mini-item-card{display:flex;justify-content:space-between;gap:10px;padding:10px 12px;border-radius:12px;background:var(--glass);border:1px solid var(--line);transition:var(--transition)}
.mini-item-card:hover{border-color:rgba(79,142,247,.10)}
.mini-item-card strong{display:block;color:var(--heading);font-family:var(--font-display);font-size:.88rem}
.mini-item-card small{display:block;color:var(--muted);margin-top:2px;font-size:.78rem}
.mini-item-right{display:flex;flex-direction:column;align-items:flex-end;gap:5px;min-width:max-content}
.empty-soft{padding:12px;border-radius:12px;background:var(--glass);border:1px solid var(--line);color:var(--muted);font-size:.88rem}
.premium-item-card{background:var(--glass)}

/* BADGES */
.badge-status{display:inline-flex;align-items:center;padding:4px 9px;border-radius:999px;font-size:.76rem;font-weight:700;font-family:var(--font-display);letter-spacing:.02em}
.badge-status.paid{background:var(--success-soft);color:var(--success)}
.badge-status.pending{background:var(--warning-soft);color:var(--warning)}
.badge-status.progress{background:var(--primary-glow);color:var(--primary)}
.badge-status.overdue{background:var(--danger-soft);color:var(--danger)}
.access-badge{display:inline-flex;align-items:center;padding:4px 9px;border-radius:999px;font-size:.76rem;font-weight:700;font-family:var(--font-display);width:max-content}
.badge-admin{background:var(--accent-soft);color:var(--accent);border:1px solid rgba(167,139,250,.18)}
.badge-lifetime{background:var(--success-soft);color:var(--success);border:1px solid rgba(52,211,153,.18)}
.badge-trial{background:var(--warning-soft);color:var(--warning);border:1px solid rgba(251,191,36,.18)}
.badge-expired,.badge-blocked{background:var(--danger-soft);color:var(--danger);border:1px solid rgba(248,113,113,.18)}
html[data-theme="light"] .badge-lifetime{color:#15803d}html[data-theme="light"] .badge-trial{color:#b45309}
html[data-theme="light"] .badge-admin{color:#7c3aed}html[data-theme="light"] .badge-expired,html[data-theme="light"] .badge-blocked{color:#b91c1c}

/* PURCHASE FORM */
.purchase-page-grid{display:grid;grid-template-columns:1fr;gap:14px}
.clean-panel-2026{padding:20px}
.section-headline{font-family:var(--font-display);font-size:1.25rem;font-weight:900;margin:0 0 4px;color:var(--heading);letter-spacing:-.01em}
.section-headline.small{font-size:1.05rem}
.section-support{color:var(--muted);margin:0;font-size:.85rem}
.compact-head-row{display:flex;justify-content:space-between;gap:14px;align-items:flex-start;flex-wrap:wrap}
.invoice-preview-card{display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:14px;background:var(--primary-glow);border:1px solid rgba(79,142,247,.14)}
.bank-logo-preview{width:36px;height:36px;border-radius:10px;object-fit:cover}
.invoice-preview-card strong{font-family:var(--font-display);font-size:.88rem}
.invoice-preview-card small{font-size:.76rem;color:var(--muted)}
.compact-fields .field{margin:0}
.logo-tile-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:8px}
.logo-tile{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:12px;border:1px solid var(--line);background:var(--glass);color:var(--text);font-family:var(--font-display);font-weight:700;font-size:.78rem;cursor:pointer;transition:var(--transition);text-align:left}
.logo-tile img{width:30px;height:30px;border-radius:8px;object-fit:cover;flex-shrink:0}
.logo-tile:hover{transform:translateY(-1px);border-color:rgba(79,142,247,.18)}
.logo-tile.active{border-color:rgba(79,142,247,.3);background:var(--primary-glow);box-shadow:0 4px 16px rgba(79,142,247,.10)}
.form-footer-actions{display:flex;gap:10px;flex-wrap:wrap}

/* CARDS PAGE */
.cards-dashboard-shell{display:grid;gap:14px}
.cards-grid-highlight{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.bank-summary-card{display:grid;gap:12px}.premium-card-summary{padding:16px}
.bank-summary-head{display:flex;justify-content:space-between;align-items:flex-start;gap:10px}
.bank-badge.big .bank-badge-icon{width:46px;height:46px;border-radius:14px;font-size:1.2rem}
.bank-summary-metrics{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.bank-summary-metrics div{padding:10px;border-radius:10px;background:var(--glass);border:1px solid var(--line)}
.bank-summary-metrics small{display:block;color:var(--muted);margin-bottom:3px;font-size:.74rem;text-transform:uppercase;letter-spacing:.04em}
.bank-summary-metrics strong{display:block;color:var(--heading);font-family:var(--font-display)}
.wide-empty-card{grid-column:1/-1}
.cards-mini-list{display:grid;gap:8px}
.bank-mini-card{display:flex;justify-content:space-between;align-items:center;gap:10px;padding:10px 12px;border-radius:12px;background:var(--glass);border:1px solid var(--line)}
.bank-mini-values{display:flex;flex-direction:column;align-items:flex-end;gap:5px;min-width:max-content}
.amount-chip,.soft-badge{display:inline-flex;align-items:center;gap:6px;padding:7px 10px;border-radius:999px;border:1px solid var(--line-strong);background:var(--glass);font-size:.85rem;font-family:var(--font-display);font-weight:800;color:var(--heading)}
.compact-tag{display:inline-flex;align-items:center;padding:6px 10px;border-radius:999px;background:var(--primary-glow);border:1px solid rgba(79,142,247,.14);font-family:var(--font-display);font-weight:700;font-size:.78rem;color:var(--primary)}
.insight-panel{align-self:start}

/* TABLES */
.table-modern{margin-bottom:0;color:var(--text);width:100%}
.table-modern>:not(caption)>*>*{padding:.7rem .6rem;border-bottom:1px solid var(--line);background:transparent;color:var(--text)}
.table-modern thead th{color:var(--muted);font-size:.74rem;text-transform:uppercase;letter-spacing:.06em;font-weight:700;font-family:var(--font-display)}
.action-row{display:flex;gap:6px;align-items:center;flex-wrap:wrap}

/* PROFILE */
.profile-card-large{display:flex;gap:14px;align-items:center;padding:14px;border-radius:16px;background:var(--glass);border:1px solid var(--line)}
.profile-card-large h3{margin:0;color:var(--heading);font-family:var(--font-display)}
.profile-card-large p{margin:4px 0 8px;color:var(--muted);font-size:.88rem}
.profile-photo-large,.profile-photo-placeholder{width:64px;height:64px;border-radius:18px}
.theme-choice-row{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}
.theme-choice{position:relative;display:flex;align-items:center;justify-content:center;padding:12px;border-radius:12px;border:1px solid var(--line-strong);background:var(--glass);font-weight:700;cursor:pointer;font-size:.88rem;transition:var(--transition)}
.theme-choice input{position:absolute;opacity:0;pointer-events:none}
.theme-choice.active{border-color:rgba(79,142,247,.24);background:var(--primary-glow)}
.admin-user-cell{display:flex;align-items:center;gap:10px}
.admin-user-cell small{display:block;color:var(--muted);margin-top:2px}
.admin-actions-stack{display:grid;gap:5px;min-width:170px}
.settings-list{display:grid;gap:5px}
.settings-row{display:flex;justify-content:space-between;gap:14px;padding:10px 0;border-bottom:1px solid var(--line)}
.settings-row:last-child{border-bottom:0}
.settings-row span{color:var(--muted);font-size:.88rem}
.settings-row strong{color:var(--heading);word-break:break-word;text-align:right;font-family:var(--font-display)}
.mobile-url-box{padding:10px 12px;border-radius:12px;background:var(--primary-glow);border:1px dashed rgba(79,142,247,.24);font-family:var(--font-display);font-weight:700;word-break:break-all;font-size:.88rem}
.settings-bullets{padding-left:18px;color:var(--muted);display:grid;gap:8px;font-size:.88rem}

/* CALC */
.calc-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.calc-result{display:flex;align-items:center;font-family:var(--font-display);font-weight:700;font-size:1rem}
.grid-form{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.grid-form .full{grid-column:1/-1}
.form-panel{max-width:1200px}
.panel{background:var(--bg-card);border:1px solid var(--line);border-radius:var(--radius);padding:16px}
.grid-kpi{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}

/* UTILS */
.mt-2{margin-top:8px}.mt-3{margin-top:14px}.mt-4{margin-top:20px}.mb-3{margin-bottom:14px}
.sidebar-overlay{display:none}.hidden{display:none!important}.d-flex{display:flex}.gap-2{gap:8px}
.dashboard-hero-grid{display:grid;grid-template-columns:1.7fr .9fr;gap:14px}
.dashboard-primary-stack{display:grid;gap:14px}
.quick-actions-mobile{display:none;grid-template-columns:repeat(2,1fr);gap:10px;padding:0;background:transparent;border:0;box-shadow:none}
.kpi-grid-compact{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
.secondary-kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.dashboard-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.profile-grid{grid-template-columns:1.1fr .9fr}
.side-action-grid{display:grid;gap:8px;margin-top:10px}
.side-action,.quick-cta{display:flex;align-items:center;justify-content:center;min-height:44px;padding:0 14px;border-radius:12px;background:var(--bg-card-2);border:1px solid var(--line-strong);color:var(--text);font-family:var(--font-display);font-weight:700}
.side-action.primary,.quick-cta.primary{background:linear-gradient(180deg,var(--primary),var(--primary-strong));color:#fff;border-color:transparent}
.side-action.secondary,.quick-cta.secondary{border-color:rgba(52,211,153,.18);color:var(--success)}
.mobile-card-table .btn{border-radius:8px}
.status-panel .status-reading-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-top:14px}
.status-reading-grid div{padding:12px;border-radius:12px;background:var(--glass);border:1px solid var(--line)}
.status-reading-grid small{display:block;color:var(--muted);margin-bottom:3px;font-size:.78rem}
.status-reading-grid strong{display:block;color:var(--heading);font-family:var(--font-display)}
.invoice-picker-panel{padding:14px;border-radius:18px;background:var(--glass);border:1px solid var(--line)}
.invoice-picker-head{display:flex;justify-content:space-between;align-items:center;gap:10px;flex-wrap:wrap}
.small-title{font-size:.96rem;font-family:var(--font-display)}
.invoice-preview-chip{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border-radius:12px;background:var(--primary-glow);border:1px solid rgba(79,142,247,.14);font-family:var(--font-display);font-weight:700}
.invoice-preview-icon,.bank-badge-icon,.invoice-tile-icon{display:inline-grid;place-items:center;flex-shrink:0;width:36px;height:36px;border-radius:10px;background:var(--glass);font-size:1rem}
.invoice-picker-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-top:12px}
.invoice-tile{display:flex;align-items:center;gap:8px;min-height:56px;padding:10px;border-radius:14px;border:1px solid var(--line);background:var(--glass);color:var(--text);font-family:var(--font-display);font-weight:700;cursor:pointer;transition:var(--transition);text-align:left;font-size:.85rem}
.invoice-tile:hover{transform:translateY(-1px);border-color:rgba(79,142,247,.18)}
.invoice-tile.active{background:var(--primary-glow);border-color:rgba(79,142,247,.24);box-shadow:0 4px 18px rgba(79,142,247,.10)}
.invoice-tile.custom{border-style:dashed}.invoice-tile-label{line-height:1.15}
.form-shell-grid{display:grid;grid-template-columns:minmax(0,1.25fr) minmax(250px,.75fr);gap:12px}
.form-panel-2026{padding:20px}
.assistant-side-panel{display:flex;flex-direction:column;justify-content:flex-start;min-height:100%}
.stacked-mobile{align-items:flex-start;gap:12px}
.equal-grid{align-items:start}
.eyebrow-label{font-family:var(--font-display);font-size:.72rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--primary);margin-bottom:8px}
.hero-mini-badges{display:flex;gap:8px;flex-wrap:wrap}
.dashboard-banner-2026{display:flex;justify-content:space-between;align-items:center;gap:14px}
.value-points-stack{display:grid;gap:8px}
.value-point-item{display:flex;gap:10px;align-items:flex-start;padding:10px 12px;border-radius:12px;background:var(--glass);border:1px solid var(--line)}
.value-point-item span:first-child{display:grid;place-items:center;width:34px;height:34px;border-radius:10px;background:var(--primary-glow);font-size:1rem}
.value-point-item strong{display:block;color:var(--heading);font-family:var(--font-display)}
.value-point-item small{display:block;color:var(--muted);margin-top:2px;font-size:.82rem}

/* RESPONSIVE */
@media (max-width:1280px){
  .kpi-row-2026{grid-template-columns:repeat(2,1fr)}
  .cards-grid-highlight{grid-template-columns:repeat(2,1fr)}
  .main-dashboard-columns{grid-template-columns:1fr}
  .logo-tile-grid{grid-template-columns:repeat(4,1fr)}
  .grid-kpi{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:1200px){
  .dashboard-hero-grid,.dashboard-grid,.profile-grid,.calc-grid{grid-template-columns:1fr}
  .kpi-grid-compact,.secondary-kpi-grid{grid-template-columns:repeat(2,1fr)}
  .grid-form{grid-template-columns:1fr 1fr}
  .form-shell-grid{grid-template-columns:1fr}
  .invoice-picker-grid{grid-template-columns:repeat(3,1fr)}
  .cards-grid-highlight{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:980px){
  .app-sidebar{transform:translateX(-105%);width:min(280px,calc(100% - 44px));border-top-right-radius:22px;border-bottom-right-radius:22px}
  .app-sidebar.is-open{transform:translateX(0)}
  .sidebar-overlay.is-open{display:block;position:fixed;inset:0;background:rgba(2,8,23,.52);backdrop-filter:blur(3px);z-index:40}
  .app-main{margin-left:0;padding:12px 12px 22px}
  .desktop-quick-actions,.desktop-page-copy{display:none}
  .page-desc{display:none}
  .header-brand-mobile{display:block}
  .app-header{position:sticky;top:0;z-index:18;padding:8px 0 10px;background:linear-gradient(180deg,var(--bg) 60%,transparent)}
  .menu-toggle-modern{width:40px;height:40px}
  .field-grid.two-col,.grid-form{grid-template-columns:1fr}
  .mobile-card-table thead{display:none}
  .mobile-card-table,.mobile-card-table tbody,.mobile-card-table tr,.mobile-card-table td{display:block;width:100%}
  .mobile-card-table tr{margin-bottom:8px;padding:12px;border:1px solid var(--line);border-radius:14px;background:var(--glass)}
  .mobile-card-table td{padding:.3rem 0 .3rem 7.8rem!important;border-bottom:1px dashed var(--line);position:relative;min-height:28px}
  .mobile-card-table td:last-child{border-bottom:0}
  .mobile-card-table td::before{content:attr(data-label);position:absolute;left:0;top:.3rem;color:var(--muted);font-weight:700;width:7.2rem;font-size:.78rem}
  .wrap-on-mobile{flex-direction:column;align-items:stretch}
  .kpi-row-2026{grid-template-columns:repeat(2,1fr)}
  .double-panel-grid{grid-template-columns:1fr}
  .logo-tile-grid{grid-template-columns:repeat(3,1fr)}
  .cards-grid-highlight{grid-template-columns:1fr}
  .dashboard-banner-2026,.bank-mini-card,.bank-summary-head,.invoice-picker-head{flex-direction:column;align-items:flex-start}
  .invoice-picker-grid{grid-template-columns:repeat(2,1fr)}
  .quick-actions-mobile{display:grid}
  .mobile-top-actions{display:grid}
  .dashboard-side-actions{display:none}
  .chart-compact{height:180px}.chart-small-mobile{height:240px}
  .status-panel .status-reading-grid{grid-template-columns:1fr 1fr}
  .panel-card,.kpi-card{padding:12px}
  .panel-title{font-size:1.05rem}
  .kpi-value{font-size:1.35rem}.kpi-focus .kpi-value{font-size:1.35rem}
  .kpi-focus{padding:12px;min-height:auto}
}
@media (max-width:720px){
  .login-page-shell{padding:12px 12px 16px}
  .login-card{padding:14px;border-radius:20px;width:min(96vw,720px)}
  .login-brand-top{margin-bottom:10px}
  .login-form-grid{grid-template-columns:1fr;gap:10px}
  .login-actions{grid-column:1;display:grid;grid-template-columns:1fr 1fr}
  .remember-line{padding:0 2px}
  .landing-content{padding:22px 0}.landing-content h1{max-width:100%;font-size:2rem}
  .landing-info-grid{grid-template-columns:1fr}
  .register-card{grid-template-columns:1fr;top:auto;transform:none;min-height:100svh;width:100%;border-radius:0;padding:20px 14px}
  .app-header{margin-bottom:8px}.page-title{font-size:1.3rem}
  .logo-tile-grid{grid-template-columns:repeat(2,1fr)}
  .logo-tile span{display:none}.logo-tile{padding:8px;justify-content:center}
  .bank-summary-metrics{grid-template-columns:1fr}
  .bank-mini-values{align-items:flex-start}
  .soft-badge{width:max-content}
  .invoice-picker-grid,.cards-grid-highlight{grid-template-columns:1fr}
  .form-panel-2026{padding:12px}.grid-kpi{grid-template-columns:1fr}
}
@media (max-width:520px){
  .login-screen{height:100svh;overflow:hidden}.login-hero{height:100svh}
  .login-page-shell{justify-content:flex-end;padding-bottom:10px}
  .login-card{padding:12px}.login-kicker{font-size:.95rem}
  .login-features-line{font-size:.84rem;line-height:1.35}
  .login-input-wrap input{height:48px;padding:0 12px}
  .button,.btn-soft,.side-action,.quick-cta{min-height:42px}
  .login-actions{gap:8px}.remember-line{font-size:.86rem}
  .app-main{padding:10px 10px 20px}
  .menu-toggle-modern{width:38px;height:38px;border-radius:10px}
  .kpi-grid-compact,.secondary-kpi-grid,.status-panel .status-reading-grid,.theme-choice-row{grid-template-columns:1fr}
  .mini-item-card{flex-direction:column;align-items:flex-start}
  .mini-item-right{align-items:flex-start}
  .mobile-card-table td{padding-left:0!important;padding-top:1.2rem!important}
  .mobile-card-table td::before{position:static;display:block;width:auto;margin-bottom:2px}
  .public-flash-wrap{top:10px;width:calc(100% - 14px)}
  .kpi-row-2026{grid-template-columns:1fr 1fr}
  .kpi-focus{padding:10px;min-height:auto}
  .kpi-focus .kpi-value{font-size:1.15rem}.kpi-focus .kpi-label{font-size:.7rem}
}

@media (max-width: 980px){
  .public-grid,.landing-grid,.auth-shell .public-grid{grid-template-columns:1fr}
  .marketing-panel h1{max-width:none}
  .landing-info-grid.clean-grid,.showcase-stats,.field-grid.two-col{grid-template-columns:1fr}
  .showcase-card-head{flex-direction:column}
}
@media (max-width: 720px){
  .public-shell{padding:18px 12px}
  .marketing-panel,.showcase-card,.auth-panel{border-radius:24px;padding:22px}
  .marketing-panel h1{font-size:clamp(1.9rem,10vw,3rem)}
  .auth-panel-top h2{font-size:1.7rem}
  .landing-actions,.auth-actions-clean{flex-direction:column;align-items:stretch}
  .landing-actions .button,.auth-actions-clean .button{width:100%}
  .feature-chip-row{display:grid;grid-template-columns:1fr 1fr}
  .feature-chip{justify-content:center;text-align:center}
  .mini-chart-card{height:180px}
  .showcase-stat strong{font-size:1.14rem}
}
@media (max-width: 520px){
  .feature-chip-row,.landing-info-grid.clean-grid,.showcase-stats{grid-template-columns:1fr}
  .brand-pill{width:100%;justify-content:center}
}


/* PUBLIC TOPBAR / MOBILE FIXES */
.public-topbar{position:relative;z-index:3;width:min(1240px,calc(100% - 28px));margin:16px auto 0;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:14px 18px;border-radius:22px;background:rgba(7,15,30,.66);border:1px solid rgba(148,163,184,.12);backdrop-filter:blur(18px);box-shadow:0 18px 40px rgba(0,0,0,.18)}
.public-topbar-brand{display:flex;align-items:center;gap:12px;min-width:0}
.public-topbar-logo{width:34px;height:34px;object-fit:contain;filter:drop-shadow(0 0 12px rgba(37,99,235,.24))}
.public-topbar-brand strong{display:block;font-family:var(--font-display);font-weight:800;color:#fff;font-size:1rem;line-height:1.1}
.public-topbar-brand small{display:block;color:#8ea5c4;font-size:.78rem;line-height:1.2;margin-top:2px}
.public-topbar-right{display:flex;align-items:center;justify-content:flex-end;gap:12px;flex:1}
.public-nav-links{display:flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:flex-end}
.public-nav-links a,.public-link-home{display:inline-flex;align-items:center;justify-content:center;min-height:42px;padding:0 16px;border-radius:12px;background:rgba(255,255,255,.03);border:1px solid rgba(148,163,184,.14);color:#d7e6f8;font-weight:700;transition:var(--transition)}
.public-nav-links a:hover,.public-link-home:hover,.public-nav-links a.active,.public-link-home.active{background:rgba(79,142,247,.12);border-color:rgba(79,142,247,.26);color:#fff}
.public-topbar-quick-login{display:flex;align-items:center;justify-content:flex-end;gap:10px;flex-wrap:wrap;width:100%}
.topbar-login-form{display:flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:flex-end}
.topbar-login-form input{height:42px;min-width:170px;padding:0 14px;border-radius:12px;border:1px solid rgba(148,163,184,.14);background:rgba(7,16,33,.72);color:#fff;outline:none;transition:var(--transition)}
.topbar-login-form input::placeholder{color:#7f93af}
.topbar-login-form input:focus{border-color:rgba(79,142,247,.45);box-shadow:0 0 0 3px rgba(79,142,247,.10)}
.topbar-login-form button{height:42px;padding:0 18px;border-radius:12px;border:1px solid rgba(255,255,255,.06);background:linear-gradient(180deg,var(--primary),var(--primary-strong));color:#fff;font-family:var(--font-display);font-weight:800;cursor:pointer;transition:var(--transition)}
.topbar-login-form button:hover{transform:translateY(-1px);box-shadow:0 8px 24px rgba(79,142,247,.24)}
.public-shell{padding-top:22px}
.auth-shell{padding-top:18px}
.auth-screen .public-shell,.landing-screen .public-shell{min-height:calc(100svh - 110px)}

@media (max-width: 1180px){
  .public-topbar{width:min(1180px,calc(100% - 20px));padding:12px 14px}
  .topbar-login-form input{min-width:150px}
}
@media (max-width: 980px){
  .public-topbar{flex-direction:column;align-items:stretch}
  .public-topbar-right{width:100%;justify-content:stretch}
  .public-nav-links,.public-topbar-quick-login,.topbar-login-form{justify-content:flex-start}
  .public-shell{padding-top:14px}
  .auth-shell .public-grid,.landing-grid,.public-grid{grid-template-columns:1fr}
  .showcase-panel{order:2}
  .marketing-panel{order:1}
}
@media (max-width: 720px){
  .public-topbar{margin-top:10px;border-radius:18px}
  .public-topbar-brand{justify-content:center}
  .public-topbar-right,.public-topbar-quick-login,.topbar-login-form,.public-nav-links{width:100%}
  .public-nav-links a,.public-link-home,.topbar-login-form button{flex:1 1 calc(33.333% - 8px)}
  .topbar-login-form input{flex:1 1 100%;min-width:0;width:100%}
  .public-nav-links{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
  .public-topbar-quick-login{display:grid;grid-template-columns:1fr;gap:8px}
  .topbar-login-form{display:grid;grid-template-columns:1fr;gap:8px}
  .public-link-home,.topbar-login-form button{width:100%}
  .auth-screen .public-shell,.landing-screen .public-shell{min-height:auto}
  .marketing-panel,.showcase-card,.auth-panel{padding:20px}
}
@media (max-width: 520px){
  .public-topbar{width:calc(100% - 12px);padding:10px 10px 12px}
  .public-topbar-brand span small{display:none}
  .public-nav-links{grid-template-columns:1fr}
  .public-nav-links a{width:100%}
  .feature-chip-row{grid-template-columns:1fr}
  .landing-actions .button,.auth-actions-clean .button{width:100%}
}

/* PUBLIC TOPBAR / TERMS / MOBILE REFINEMENT */
.public-topbar{position:fixed;top:16px;left:50%;transform:translateX(-50%);z-index:50;width:min(1200px,calc(100% - 40px));display:flex;align-items:center;justify-content:space-between;gap:14px;padding:10px 12px;border-radius:22px;background:rgba(6,15,30,.72);border:1px solid rgba(148,163,184,.16);backdrop-filter:blur(18px);box-shadow:0 18px 50px rgba(0,0,0,.22)}
.public-topbar-brand{display:flex;align-items:center;gap:10px;font-family:var(--font-display);font-weight:900;color:#fff;min-width:max-content}
.public-topbar-brand img{width:28px;height:28px;filter:drop-shadow(0 0 12px rgba(52,211,153,.32))}
.public-nav{display:flex;align-items:center;justify-content:flex-end;gap:8px;flex-wrap:wrap}
.public-nav a{display:inline-flex;align-items:center;justify-content:center;min-height:38px;padding:0 14px;border-radius:999px;border:1px solid rgba(148,163,184,.14);background:rgba(255,255,255,.035);color:#c8d8ec;font-family:var(--font-display);font-weight:800;font-size:.9rem;transition:var(--transition)}
.public-nav a:hover,.public-nav a.active{color:#fff;background:linear-gradient(135deg,rgba(59,130,246,.34),rgba(16,185,129,.28));border-color:rgba(52,211,153,.28);box-shadow:0 8px 24px rgba(16,185,129,.12)}
.public-shell{padding-top:104px;padding-bottom:34px;align-items:flex-start;min-height:100svh;overflow-x:hidden}
.public-grid{align-items:stretch}
.showcase-card,.marketing-panel,.auth-panel{min-width:0}
.terms-check{display:flex;gap:10px;align-items:flex-start;padding:14px 16px;border-radius:16px;background:rgba(255,255,255,.035);border:1px solid rgba(148,163,184,.12);color:#cfe0f4;line-height:1.55;font-size:.92rem}
.terms-check input{margin-top:5px;accent-color:#10b981;flex-shrink:0}
.terms-check a{color:#6ee7b7;font-weight:800;text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:3px}
.terms-shell{justify-content:center;align-items:flex-start}
.terms-card{width:min(860px,100%);padding:34px;border-radius:30px;background:linear-gradient(180deg,rgba(8,18,35,.92),rgba(6,14,28,.9));border:1px solid rgba(148,163,184,.14);box-shadow:0 24px 80px rgba(0,0,0,.30);backdrop-filter:blur(18px)}
.terms-card h1{font-family:var(--font-display);font-size:clamp(2rem,5vw,3.3rem);line-height:1.05;letter-spacing:-.04em;color:#fff;margin:22px 0 16px}
.terms-card p{color:#c5d4e6;line-height:1.75;margin:0 0 14px;font-size:1rem}
.terms-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:22px}
@media (max-width:980px){
  .public-topbar{position:sticky;top:10px;transform:none;left:auto;width:calc(100% - 24px);margin:10px auto 0;border-radius:18px}
  .public-body{overflow-y:auto}
  .public-shell{padding:18px 12px 28px;min-height:auto;display:block}
  .public-grid,.landing-grid,.auth-shell .public-grid{display:grid;grid-template-columns:1fr!important;gap:14px;width:100%}
  .showcase-panel{display:block}
  .marketing-panel h1{max-width:none}
}
@media (max-width:720px){
  .public-topbar{align-items:flex-start;gap:10px;padding:10px;flex-direction:column}
  .public-topbar-brand{width:100%;justify-content:center}
  .public-nav{width:100%;display:grid;grid-template-columns:repeat(3,1fr);gap:6px}
  .public-nav a{padding:0 8px;font-size:.82rem;min-height:36px}
  .marketing-panel,.showcase-card,.auth-panel,.terms-card{padding:18px;border-radius:22px;width:100%}
  .marketing-panel h1{font-size:clamp(2rem,12vw,3.2rem);line-height:1.02}
  .marketing-panel p{font-size:.98rem;line-height:1.65}
  .landing-info-grid.clean-grid,.showcase-stats,.field-grid.two-col{grid-template-columns:1fr!important}
  .feature-chip-row{grid-template-columns:1fr 1fr!important}
  .auth-copy-panel{min-height:auto}
  .auth-panel-top h2{font-size:1.65rem}
  .login-actions,.auth-actions-clean,.register-actions{display:grid!important;grid-template-columns:1fr!important;gap:10px;width:100%}
  .login-actions .button,.auth-actions-clean .button,.register-actions .button{width:100%}
  .mini-chart-card{height:165px}
  .showcase-list-item{padding:14px}
}
@media (max-width:480px){
  .public-topbar{width:calc(100% - 16px)}
  .public-nav{grid-template-columns:1fr;gap:6px}
  .brand-pill{width:100%;justify-content:center;text-align:center}
  .feature-chip-row{grid-template-columns:1fr!important}
  .marketing-panel,.showcase-card,.auth-panel,.terms-card{padding:16px}
  .marketing-panel h1{font-size:2.05rem}
  .showcase-stat strong{font-size:1.08rem}
  .terms-card h1{font-size:2rem}
}

/* Final mobile safety: public pages must scroll naturally */
@media (max-width:720px){
  body.public-body,.landing-screen,.auth-screen,.login-screen,.register-screen{height:auto!important;min-height:100svh!important;overflow-x:hidden!important;overflow-y:auto!important}
  .public-shell{min-height:auto!important}
}


/* === V16 PUBLIC PRODUCTION FIXES === */
.public-flash-wrap{
  position:fixed!important;
  left:50%!important;
  top:92px!important;
  transform:translateX(-50%)!important;
  z-index:99999!important;
  width:min(92vw,720px)!important;
  margin:0!important;
  pointer-events:none;
}

.public-flash-wrap .flash-alert{
  pointer-events:auto;
  box-shadow:0 18px 45px rgba(0,0,0,.35);
  white-space:normal;
  word-break:break-word;
}
.public-topbar{
  margin:12px auto 0!important;
  padding:12px 16px!important;
  min-height:66px!important;
}
.public-topbar-quick-login,
.topbar-login-form{
  display:none!important;
}
.public-shell{
  min-height:calc(100svh - 92px)!important;
  padding:14px 20px 22px!important;
  align-items:center!important;
}
.public-grid{
  gap:16px!important;
}
.marketing-panel,
.showcase-card,
.auth-panel{
  border-radius:26px!important;
}
.marketing-panel{
  padding:26px!important;
}
.showcase-card,
.auth-panel{
  padding:24px!important;
}
.marketing-panel h1{
  font-size:clamp(2rem,3.15vw,3.55rem)!important;
  max-width:13.5ch!important;
  line-height:1.04!important;
  margin:8px 0 12px!important;
}
.auth-copy-panel h1{
  font-size:clamp(2rem,3.05vw,3.35rem)!important;
  max-width:13.5ch!important;
}
.marketing-panel p{
  font-size:.98rem!important;
  line-height:1.55!important;
}
.hero-kicker{
  margin-top:16px!important;
  margin-bottom:8px!important;
}
.landing-actions{
  margin:18px 0 14px!important;
}
.feature-chip-row{
  margin-bottom:14px!important;
}
.landing-info-grid.clean-grid{
  gap:10px!important;
}
.landing-info-box{
  padding:14px!important;
  border-radius:16px!important;
}
.landing-info-box span{
  font-size:.88rem!important;
}
.showcase-card-head{
  margin-bottom:14px!important;
}
.showcase-card-head h2{
  font-size:1.45rem!important;
}
.showcase-stats{
  gap:10px!important;
  margin-bottom:12px!important;
}
.showcase-stat{
  padding:14px!important;
  border-radius:16px!important;
}
.showcase-stat strong{
  font-size:1.18rem!important;
}
.mini-chart-card{
  height:170px!important;
  margin:0 0 12px!important;
}
.mini-bars{
  height:92px!important;
  bottom:20px!important;
}
.showcase-list{
  gap:9px!important;
}
.showcase-list-item{
  padding:12px 14px!important;
  border-radius:15px!important;
}
.showcase-list-item strong{
  font-size:.94rem!important;
}
.showcase-list-item span{
  font-size:.86rem!important;
  line-height:1.45!important;
}
.auth-grid{
  grid-template-columns:.96fr 1fr!important;
}
.auth-panel-top{
  margin-bottom:14px!important;
}
.auth-panel-top h2{
  font-size:1.82rem!important;
}
.auth-panel-top p{
  font-size:.94rem!important;
}
.auth-form-clean{
  gap:12px!important;
}
.auth-footer-note{
  margin-top:14px!important;
  padding-top:12px!important;
}
.compact-feature-list{
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:10px 12px!important;
}
.compact-feature-list .feature-list-item{
  font-size:.92rem!important;
}
.field-grid.two-col{
  gap:12px!important;
}
.terms-check{
  margin-top:0!important;
  font-size:.88rem!important;
}

/* Desktop menor: mantém o conteúdo cabendo melhor sem cortar chamadas */
@media (max-height: 820px) and (min-width: 981px){
  .public-topbar{margin-top:8px!important;min-height:58px!important;padding:10px 14px!important}
  .public-shell{min-height:calc(100svh - 78px)!important;padding-top:10px!important;padding-bottom:14px!important}
  .marketing-panel{padding:22px!important}
  .showcase-card,.auth-panel{padding:22px!important}
  .marketing-panel h1{font-size:clamp(1.8rem,2.75vw,3.05rem)!important}
  .auth-copy-panel h1{font-size:clamp(1.8rem,2.65vw,2.95rem)!important}
  .marketing-panel p{font-size:.92rem!important}
  .hero-kicker{margin-top:12px!important}
  .landing-actions{margin:14px 0 10px!important}
  .feature-chip{padding:7px 10px!important;font-size:.8rem!important}
  .landing-info-box{padding:12px!important}
  .mini-chart-card{height:145px!important}
  .showcase-stat{padding:12px!important}
  .showcase-list-item{padding:10px 12px!important}
  .feature-list-clean{margin-top:16px!important}
  .auth-panel-top h2{font-size:1.6rem!important}
}

/* Tablet e celular: não quebra a acessibilidade; organiza em pilha com rolagem normal */
@media (max-width: 980px){
  .public-topbar{
    position:relative!important;
    width:calc(100% - 20px)!important;
    flex-direction:column!important;
    align-items:stretch!important;
    gap:10px!important;
  }
  .public-topbar-brand{
    justify-content:center!important;
  }
  .public-nav-links{
    width:100%!important;
    display:grid!important;
    grid-template-columns:repeat(3,1fr)!important;
    gap:8px!important;
  }
  .public-nav-links a{
    min-height:40px!important;
    padding:0 10px!important;
  }
  .public-shell{
    min-height:auto!important;
    padding:14px 10px 24px!important;
    align-items:flex-start!important;
  }
  .public-grid,
  .landing-grid,
  .auth-grid,
  .auth-shell .public-grid{
    grid-template-columns:1fr!important;
    gap:12px!important;
  }
  .marketing-panel,
  .showcase-card,
  .auth-panel{
    padding:20px!important;
    border-radius:22px!important;
  }
  .marketing-panel h1,
  .auth-copy-panel h1{
    max-width:none!important;
    font-size:clamp(1.85rem,8vw,3rem)!important;
  }
  .compact-feature-list{
    grid-template-columns:1fr!important;
  }
  .showcase-panel{order:2!important}
  .marketing-panel{order:1!important}
  .auth-panel{order:2!important}
  .auth-copy-panel{order:1!important}
}
@media (max-width: 720px){
  .public-body{overflow-x:hidden!important}
  .public-topbar{margin-top:8px!important}
  .public-topbar-brand small{font-size:.72rem!important}
  .public-nav-links a{font-size:.88rem!important}
  .landing-actions,
  .auth-actions-clean{
    display:grid!important;
    grid-template-columns:1fr 1fr!important;
    gap:8px!important;
  }
  .landing-actions .button,
  .auth-actions-clean .button{
    width:100%!important;
    min-height:44px!important;
  }
  .feature-chip-row{
    display:grid!important;
    grid-template-columns:1fr 1fr!important;
    gap:8px!important;
  }
  .landing-info-grid.clean-grid,
  .showcase-stats,
  .field-grid.two-col{
    grid-template-columns:1fr!important;
  }
  .mini-chart-card{height:150px!important}
}
@media (max-width: 460px){
  .public-nav-links{grid-template-columns:1fr!important}
  .landing-actions,
  .auth-actions-clean,
  .feature-chip-row{
    grid-template-columns:1fr!important;
  }
  .marketing-panel h1,
  .auth-copy-panel h1{
    font-size:clamp(1.75rem,10vw,2.6rem)!important;
  }
}


/* === V17 MOBILE LOGIN/CADASTRO ORDER FIX === */
/* No celular, o formulário deve aparecer primeiro ao abrir Login ou Criar conta.
   A chamada comercial fica abaixo, preservando o desktop e as funções internas. */
@media (max-width: 980px){
  .auth-screen .public-grid.auth-grid{
    display:grid!important;
    grid-template-columns:1fr!important;
  }
  .auth-screen .auth-panel{
    order:1!important;
  }
  .auth-screen .auth-copy-panel{
    order:2!important;
  }
  .auth-screen .auth-copy-panel{
    margin-top:0!important;
  }
}

/* Em telas pequenas, deixa o formulário ainda mais direto e sem excesso de altura. */
@media (max-width: 720px){
  .auth-screen .public-shell{
    padding-top:10px!important;
  }
  .auth-screen .auth-panel{
    padding:20px!important;
  }
  .auth-screen .auth-panel-top{
    margin-bottom:12px!important;
  }
  .auth-screen .auth-panel-top h2{
    font-size:1.75rem!important;
  }
  .auth-screen .auth-panel-top p{
    font-size:.92rem!important;
    line-height:1.45!important;
  }
  .auth-screen .auth-form-clean{
    gap:10px!important;
  }
  .auth-screen .auth-copy-panel{
    padding:18px!important;
  }
  .auth-screen .auth-copy-panel h1{
    font-size:1.75rem!important;
  }
  .auth-screen .compact-feature-list{
    grid-template-columns:1fr!important;
  }
}

/* Pagamento InfinitePay */
.payment-shell {
  padding-top: clamp(22px, 4vw, 46px);
  padding-bottom: 42px;
}
.payment-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(340px, 470px);
  gap: clamp(18px, 3vw, 34px);
  align-items: stretch;
}
.payment-info-card,
.payment-panel {
  min-height: 100%;
}
.payment-benefits {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
  margin-top: 24px;
}
.payment-benefits div,
.webhook-note,
.payment-warning-box,
.payment-current-box {
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.07);
  border-radius: 18px;
  padding: 14px;
}
.payment-benefits strong,
.payment-benefits span {
  display: block;
}
.payment-benefits strong {
  font-size: .78rem;
  opacity: .74;
  text-transform: uppercase;
  letter-spacing: .06em;
}
.payment-benefits span {
  margin-top: 5px;
  font-weight: 800;
}
.webhook-note {
  margin-top: 18px;
  word-break: break-word;
}
.webhook-note strong,
.webhook-note code {
  display: block;
}
.webhook-note code {
  margin-top: 8px;
  color: inherit;
  opacity: .9;
}
.inline-logout-form {
  margin: 0;
}
.inline-logout-form button {
  border: 0;
  background: transparent;
  color: inherit;
  font: inherit;
  cursor: pointer;
}
.payment-warning-box {
  margin: 14px 0 18px;
}
.payment-warning-box p {
  margin: 8px 0 0;
}
.payment-create-form {
  margin-top: 18px;
}
.payment-create-form small {
  display: block;
  margin-top: 6px;
  opacity: .72;
}
.payment-current-box {
  margin-top: 22px;
}
.payment-status-row {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: center;
  margin-bottom: 12px;
}
.payment-status {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 6px 10px;
  border-radius: 999px;
  font-size: .78rem;
  font-weight: 800;
  background: rgba(255, 193, 7, .14);
  border: 1px solid rgba(255, 193, 7, .28);
}
.status-paid {
  background: rgba(25, 135, 84, .16);
  border-color: rgba(25, 135, 84, .28);
}
.payment-meta {
  margin: 6px 0;
  font-size: .9rem;
  opacity: .82;
  word-break: break-word;
}
.pix-qr-wrap {
  display: grid;
  place-items: center;
  margin: 18px auto;
  padding: 14px;
  background: #fff;
  border-radius: 22px;
  max-width: 280px;
}
.pix-qr-wrap img {
  display: block;
  width: 100%;
  height: auto;
}
.pix-copy-label {
  display: block;
  margin: 12px 0 8px;
  font-weight: 800;
}
.pix-copy-text {
  width: 100%;
  min-height: 118px;
  resize: vertical;
  border-radius: 16px;
  padding: 12px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(0,0,0,.18);
  color: inherit;
  font-size: .86rem;
}
.payment-check-form {
  margin-top: 10px;
}
.w-100 {
  width: 100%;
}
@media (max-width: 900px) {
  .payment-grid {
    grid-template-columns: 1fr;
  }
  .payment-benefits {
    grid-template-columns: 1fr;
  }
}
