/* PULSE — styles.css — Light mode, green gradient brand */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#F4F7F5;--bg2:#FFF;--bg3:#EBF2EE;--bg4:#DDE9E3;
  --text:#0A1A12;--text2:#223328;--muted:#5A7A67;--dim:#9CB8A8;
  --border:rgba(10,60,30,.1);--border2:rgba(10,60,30,.06);
  --g1:#0D6E3F;--g2:#16A85F;--g3:#22C87A;
  --grad:linear-gradient(135deg,#0D6E3F 0%,#16A85F 55%,#22C87A 100%);
  --grad-soft:linear-gradient(135deg,#E8F5EE 0%,#D4EFE1 100%);
  --glow:rgba(22,168,95,.15);--glow2:rgba(22,168,95,.08);
  --amber:#92600A;--amber-bg:rgba(146,96,10,.07);--amber-b:rgba(146,96,10,.18);
  --blue:#1A4FA0;--blue-bg:rgba(26,79,160,.07);--blue-b:rgba(26,79,160,.15);
  --red:#C0392B;--red-bg:rgba(192,57,43,.06);--red-b:rgba(192,57,43,.15);
  --purple:#6D28D9;--purple-bg:rgba(109,40,217,.07);--purple-b:rgba(109,40,217,.15);
  --r:6px;--r-md:10px;--r-lg:14px;--r-xl:20px;
  --sh:0 1px 4px rgba(0,0,0,.06),0 2px 8px rgba(0,0,0,.04);
  --sh-md:0 4px 16px rgba(0,0,0,.08),0 1px 4px rgba(0,0,0,.04);
  --sh-lg:0 8px 32px rgba(0,0,0,.10),0 2px 8px rgba(0,0,0,.05);
  --nav:52px;
}
html,body{min-height:100%;background:var(--bg);color:var(--text);font-family:'DM Sans',sans-serif;font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased;overflow-x:hidden}
button{cursor:pointer;font-family:inherit;background:none;border:none}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-thumb{background:rgba(0,0,0,.12);border-radius:3px}

/* NAV */
.topnav{position:sticky;top:0;height:var(--nav);z-index:100;background:rgba(244,247,245,.96);backdrop-filter:blur(14px);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 20px;gap:0}
.logo{font-family:'Bebas Neue',sans-serif;font-size:24px;letter-spacing:.08em;flex-shrink:0;margin-right:24px;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.nav-tabs-top{display:flex;align-items:center;gap:2px;flex:1;overflow-x:auto}
.nav-tabs-top::-webkit-scrollbar{display:none}
.ntab{padding:6px 12px;border-radius:var(--r);font-size:12px;font-weight:500;color:var(--muted);white-space:nowrap;transition:all .12s;cursor:pointer}
.ntab:hover{background:var(--bg3);color:var(--text)}
.ntab.active{background:var(--grad-soft);color:var(--g1);font-weight:700;border:1px solid rgba(13,110,63,.12)}
.nav-r{display:flex;align-items:center;gap:10px;margin-left:auto;flex-shrink:0}
.nav-av{width:30px;height:30px;border-radius:50%;background:var(--grad);display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:800;color:#fff;font-family:'DM Mono',monospace;flex-shrink:0}
.nav-name{font-size:12px;font-weight:600;color:var(--text2)}
.btn-so{padding:5px 12px;border-radius:20px;font-size:11px;font-weight:600;color:var(--muted);border:1px solid var(--border);transition:all .12s}
.btn-so:hover{color:var(--red);border-color:var(--red-b)}

/* MOBILE NAV */
.mobile-topnav{display:none;align-items:center;justify-content:space-between;padding:0 16px;height:var(--nav);background:rgba(244,247,245,.96);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100}
.mobile-logo{font-family:'Bebas Neue',sans-serif;font-size:22px;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hamburger{width:34px;height:34px;border-radius:var(--r);background:var(--bg3);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:16px}
.sidebar-overlay{position:fixed;inset:0;background:rgba(0,0,0,.25);z-index:199;display:none}
.sidebar-overlay.open{display:block}
.drawer-nav{position:fixed;left:-260px;top:0;bottom:0;width:240px;background:var(--bg2);border-right:1px solid var(--border);z-index:200;transition:left .22s ease;overflow-y:auto;padding:20px 12px}
.drawer-nav.open{left:0}

/* LAYOUT */
.shell{display:flex;flex-direction:column;min-height:100vh}
.body{flex:1;padding:24px 20px;max-width:1120px;width:100%;margin:0 auto}
.view{display:none}.view.active{display:block;animation:su .18s ease both}
@keyframes su{from{transform:translateY(12px);opacity:0}to{transform:none;opacity:1}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}

/* GRIDS */
.g2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.g3{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.g4{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.gauto{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:14px}

/* CARDS */
.card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r-lg);padding:18px;box-shadow:var(--sh)}
.ctitle{font-family:'DM Mono',monospace;font-size:9px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-bottom:12px}
.card-sub{font-size:12px;color:var(--muted);margin-top:-8px;margin-bottom:12px}

/* STAT */
.stat{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r-lg);padding:18px 16px;position:relative;overflow:hidden;box-shadow:var(--sh)}
.stat::before{content:'';position:absolute;top:0;left:0;right:0;height:3px}
.sg::before{background:var(--grad)}.sa::before{background:linear-gradient(90deg,var(--amber),#F59E0B)}
.sb::before{background:linear-gradient(90deg,var(--blue),#3B82F6)}.sp::before{background:linear-gradient(90deg,var(--purple),#A78BFA)}
.sr::before{background:linear-gradient(90deg,var(--red),#E74C3C)}
.sv{font-family:'Bebas Neue',sans-serif;font-size:clamp(26px,4vw,40px);line-height:1;letter-spacing:.02em;margin-bottom:4px}
.sl{font-family:'DM Mono',monospace;font-size:9px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}

/* BADGES */
.badge{display:inline-flex;align-items:center;padding:3px 9px;border-radius:20px;font-size:9px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;font-family:'DM Mono',monospace}
.bg{background:rgba(13,110,63,.08);color:var(--g1);border:1px solid rgba(13,110,63,.2)}
.bga{background:var(--amber-bg);color:var(--amber);border:1px solid var(--amber-b)}
.bb{background:var(--blue-bg);color:var(--blue);border:1px solid var(--blue-b)}
.bm{background:var(--bg3);color:var(--muted);border:1px solid var(--border)}
.bp{background:var(--purple-bg);color:var(--purple);border:1px solid var(--purple-b)}
.br{background:var(--red-bg);color:var(--red);border:1px solid var(--red-b)}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;gap:6px;padding:7px 18px;border-radius:20px;font-size:12px;font-weight:600;transition:all .14s;cursor:pointer;border:none;font-family:inherit}
.btn-p{background:var(--grad);color:#fff;box-shadow:0 4px 14px var(--glow)}
.btn-p:hover{box-shadow:0 6px 20px rgba(22,168,95,.28);transform:translateY(-1px)}
.btn-p:disabled{opacity:.5;cursor:not-allowed;transform:none}
.btn-g{background:transparent;color:var(--text2);border:1px solid var(--border)}
.btn-g:hover{background:var(--bg3)}
.btn-danger{background:var(--red-bg);color:var(--red);border:1px solid var(--red-b)}
.btn-danger:hover{background:var(--red);color:#fff}
.btn-sm{padding:5px 12px;font-size:11px}
.btn-xs{padding:4px 10px;font-size:10px}

/* TABLE */
.tbl{width:100%;border-collapse:collapse}
.tbl th{font-family:'DM Mono',monospace;font-size:9px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);padding:10px 14px;text-align:left;background:var(--bg3);border-bottom:1px solid var(--border)}
.tbl td{padding:11px 14px;border-bottom:1px solid var(--border2);vertical-align:middle;font-size:13px}
.tbl tbody tr{transition:background .1s}.tbl tbody tr:hover{background:var(--bg3)}
.tbl tbody tr:hover td:first-child{border-left:2px solid var(--g2);padding-left:12px}
.tbl tbody tr:last-child td{border-bottom:none}
.tbl-wrap{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh)}
.tbl-hdr{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--border);background:var(--bg3);flex-wrap:wrap;gap:8px}
.tbl-hdr-title{font-size:13px;font-weight:600}

/* AVATAR */
.av{border-radius:var(--r);background:var(--grad-soft);border:1px solid rgba(13,110,63,.18);display:flex;align-items:center;justify-content:center;font-family:'DM Mono',monospace;font-weight:700;color:var(--g1);flex-shrink:0}

/* ATHLETE CARD */
.ac{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r-lg);padding:14px;cursor:pointer;transition:box-shadow .15s,transform .15s;box-shadow:var(--sh)}
.ac:hover{box-shadow:var(--sh-md);transform:translateY(-2px)}

/* AGENCY CARD */
.agency-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r-lg);padding:18px;cursor:pointer;transition:box-shadow .15s,transform .15s,border-color .15s;box-shadow:var(--sh);position:relative}
.agency-card:hover{box-shadow:var(--sh-md);transform:translateY(-2px);border-color:rgba(13,110,63,.2)}
.agency-card-arrow{position:absolute;top:16px;right:16px;color:var(--dim);font-size:14px;transition:color .12s}
.agency-card:hover .agency-card-arrow{color:var(--g1)}

/* HERO — no overflow:hidden on outer */
.hero{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r-lg);margin-bottom:16px;box-shadow:var(--sh-md)}
.hero-banner{height:130px;background:var(--grad);border-radius:var(--r-lg) var(--r-lg) 0 0;position:relative;overflow:hidden}
.hero-banner::after{content:'';position:absolute;inset:0;background:repeating-linear-gradient(-45deg,transparent,transparent 18px,rgba(255,255,255,.04) 18px,rgba(255,255,255,.04) 19px)}
.hero-body{padding:0 22px 22px}
.hero-av-wrap{margin-top:-50px;margin-bottom:14px;display:inline-block;position:relative;z-index:2}
.hero-av{width:96px;height:96px;border-radius:14px;border:4px solid var(--bg2);background:var(--grad);display:flex;align-items:center;justify-content:center;font-family:'Bebas Neue',sans-serif;font-size:32px;color:#fff;box-shadow:0 4px 20px rgba(0,0,0,.18);overflow:hidden}
.hero-av img{width:100%;height:100%;object-fit:cover}
.hero-name{font-family:'Bebas Neue',sans-serif;font-size:clamp(22px,4vw,34px);letter-spacing:.02em;line-height:1;margin-bottom:5px}
.hero-meta{font-size:13px;color:var(--muted);margin-bottom:12px}
.hero-badges{display:flex;gap:7px;flex-wrap:wrap;align-items:center}

/* AGENCY PROFILE HEADER */
.ag-header{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r-lg);padding:22px 24px;margin-bottom:20px;box-shadow:var(--sh)}
.ag-logo{width:60px;height:60px;border-radius:var(--r-md);background:var(--grad);display:flex;align-items:center;justify-content:center;font-family:'Bebas Neue',sans-serif;font-size:22px;color:#fff;flex-shrink:0}
.ag-name{font-family:'Bebas Neue',sans-serif;font-size:clamp(18px,3vw,26px);letter-spacing:.03em;line-height:1;margin-bottom:4px}
.ag-meta{font-size:12px;color:var(--muted)}
.ag-stats{display:flex;gap:24px;margin-top:16px;flex-wrap:wrap}
.ag-sv{font-family:'Bebas Neue',sans-serif;font-size:26px;line-height:1}
.ag-sl{font-family:'DM Mono',monospace;font-size:9px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-top:2px}

/* PAGE TABS */
.page-tabs{display:flex;gap:0;border-bottom:1px solid var(--border);margin-bottom:20px;overflow-x:auto}
.page-tabs::-webkit-scrollbar{display:none}
.ptab{padding:10px 16px;font-size:12px;font-weight:600;color:var(--muted);border-bottom:2px solid transparent;margin-bottom:-1px;cursor:pointer;white-space:nowrap;transition:all .12s;background:none;border-top:none;border-left:none;border-right:none}
.ptab:hover{color:var(--text)}.ptab.active{color:var(--g1);border-bottom-color:var(--g1);font-weight:700}

/* INFO ROWS */
.ir{display:flex;justify-content:space-between;align-items:center;padding:9px 0;border-bottom:1px solid var(--border2);font-size:13px}
.ir:last-child{border-bottom:none}
.ik{font-size:11px;font-weight:600;color:var(--muted)}.iv{font-weight:600}

/* FORM ELEMENTS */
.form-group{display:flex;flex-direction:column;gap:5px;margin-bottom:14px}
.form-label{font-family:'DM Mono',monospace;font-size:9px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.form-input{padding:9px 12px;border:1.5px solid var(--border);border-radius:var(--r);font-size:13px;background:var(--bg2);color:var(--text);outline:none;transition:border-color .15s,box-shadow .15s;font-family:inherit;width:100%}
.form-input:focus{border-color:var(--g2);box-shadow:0 0 0 3px var(--glow2)}
.form-input:read-only{background:var(--bg3);color:var(--muted);cursor:default}
.form-select{padding:9px 12px;border:1.5px solid var(--border);border-radius:var(--r);font-size:13px;background:var(--bg2);color:var(--text);outline:none;transition:border-color .15s;font-family:inherit;width:100%;cursor:pointer}
.form-select:focus{border-color:var(--g2)}
.form-textarea{padding:9px 12px;border:1.5px solid var(--border);border-radius:var(--r);font-size:13px;background:var(--bg2);color:var(--text);outline:none;transition:border-color .15s;font-family:inherit;width:100%;resize:vertical;min-height:80px}
.form-textarea:focus{border-color:var(--g2);box-shadow:0 0 0 3px var(--glow2)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.form-actions{display:flex;gap:8px;margin-top:4px;justify-content:flex-end}

/* MODAL */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.3);backdrop-filter:blur(4px);z-index:500;display:flex;align-items:center;justify-content:center;padding:20px;animation:fadeIn .15s ease}
.modal-box{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r-xl);padding:28px;width:100%;max-width:520px;box-shadow:var(--sh-lg);animation:su .2s ease both;max-height:90vh;overflow-y:auto}
.modal-title{font-family:'Bebas Neue',sans-serif;font-size:22px;letter-spacing:.03em;margin-bottom:4px}
.modal-sub{font-size:12px;color:var(--muted);margin-bottom:20px}
.modal-close{position:absolute;top:16px;right:16px;width:28px;height:28px;border-radius:50%;background:var(--bg3);display:flex;align-items:center;justify-content:center;font-size:14px;color:var(--muted);cursor:pointer;transition:all .12s}
.modal-close:hover{background:var(--bg4);color:var(--text)}

/* DOC ROW */
.doc-row{display:flex;align-items:center;justify-content:space-between;padding:10px 0;border-bottom:1px solid var(--border2);gap:12px}
.doc-row:last-child{border-bottom:none}
.doc-icon{width:32px;height:32px;border-radius:var(--r);background:var(--bg3);display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0}

/* NOTE BOX */
.note{border-radius:var(--r-md);padding:14px 16px}
.ng{background:rgba(13,110,63,.06);border:1px solid rgba(13,110,63,.15)}
.na{background:var(--amber-bg);border:1px solid var(--amber-b)}
.nh{font-family:'DM Mono',monospace;font-size:9px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;margin-bottom:6px}
.ng .nh{color:var(--g1)}.na .nh{color:var(--amber)}
.nt{font-size:12px;color:var(--muted);line-height:1.7}

/* SIGNAL BADGES */
.sig-strong{background:rgba(13,110,63,.1);color:var(--g1);border:1px solid rgba(13,110,63,.2);padding:3px 9px;border-radius:var(--r);font-size:9px;font-weight:700;font-family:'DM Mono',monospace;text-transform:uppercase}
.sig-avg{background:var(--amber-bg);color:var(--amber);border:1px solid var(--amber-b);padding:3px 9px;border-radius:var(--r);font-size:9px;font-weight:700;font-family:'DM Mono',monospace;text-transform:uppercase}
.sig-low{background:var(--red-bg);color:var(--red);border:1px solid var(--red-b);padding:3px 9px;border-radius:var(--r);font-size:9px;font-weight:700;font-family:'DM Mono',monospace;text-transform:uppercase}

/* MISC */
.stars{color:#C8A422;font-size:11px;letter-spacing:1px}
.dot{display:inline-block;width:7px;height:7px;border-radius:50%;flex-shrink:0}
.dot-g{background:var(--g2)}.dot-a{background:var(--amber)}.dot-r{background:var(--red)}
.sw{position:relative;flex:1;min-width:160px;max-width:280px}
.si{width:100%;padding:8px 12px 8px 32px;border:1px solid var(--border);border-radius:20px;font-size:13px;background:var(--bg2);color:var(--text);outline:none;transition:border-color .15s;font-family:inherit}
.si:focus{border-color:var(--g2);box-shadow:0 0 0 3px var(--glow2)}
.sic{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--dim);font-size:14px;pointer-events:none}
.eyebrow{font-family:'DM Mono',monospace;font-size:9px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);margin-bottom:4px}
.ptitle{font-family:'Bebas Neue',sans-serif;font-size:clamp(24px,5vw,38px);letter-spacing:.03em;line-height:1;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:4px}
.psub{font-size:13px;color:var(--muted);margin-bottom:22px}
.slabel{font-family:'DM Mono',monospace;font-size:9px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-bottom:10px;margin-top:20px}
.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 20px;text-align:center;gap:8px;color:var(--muted);font-size:13px}
.empty-icon{font-size:32px;opacity:.2;margin-bottom:4px}
.read-only-banner{background:var(--amber-bg);border:1px solid var(--amber-b);border-radius:var(--r);padding:8px 14px;font-size:12px;color:var(--amber);margin-bottom:16px;font-weight:500}
.spin-wrap{display:flex;align-items:center;justify-content:center;padding:48px;flex-direction:column;gap:12px}
.spin{width:32px;height:32px;border:2px solid rgba(22,168,95,.15);border-top-color:var(--g2);border-radius:50%;animation:sp .8s linear infinite}
@keyframes sp{to{transform:rotate(360deg)}}
.spin-txt{font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);font-family:'DM Mono',monospace}

/* LOGIN */
.lw{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(160deg,#f0f9f4 0%,#e4f4eb 40%,#f4f7f5 100%);position:relative;overflow:hidden;padding:20px}
.lgrid{position:absolute;inset:0;background-image:linear-gradient(rgba(13,110,63,.08) 1px,transparent 1px),linear-gradient(90deg,rgba(13,110,63,.08) 1px,transparent 1px);background-size:44px 44px;mask-image:radial-gradient(ellipse at center,black 30%,transparent 80%)}
.lcard{background:var(--bg2);border:1px solid rgba(13,110,63,.12);border-radius:var(--r-xl);padding:40px;width:100%;max-width:390px;position:relative;box-shadow:0 8px 40px rgba(13,110,63,.1),0 2px 8px rgba(0,0,0,.06);animation:su .3s ease both}
.llogo{font-family:'Bebas Neue',sans-serif;font-size:48px;letter-spacing:.08em;line-height:1;margin-bottom:2px;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.ltag{font-family:'DM Mono',monospace;font-size:9px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-bottom:8px}
.ldiv{height:2px;background:var(--grad);border-radius:2px;margin-bottom:28px;opacity:.2}
.llbl{font-family:'DM Mono',monospace;font-size:9px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);display:block;margin-bottom:5px}
.linput{width:100%;padding:11px 14px;border:1.5px solid var(--border);border-radius:var(--r);font-size:14px;background:var(--bg2);color:var(--text);outline:none;margin-bottom:16px;transition:border-color .15s,box-shadow .15s;font-family:inherit}
.linput:focus{border-color:var(--g2);box-shadow:0 0 0 3px var(--glow2)}
.lbtn{width:100%;padding:13px;background:var(--grad);color:#fff;border:none;border-radius:20px;font-size:14px;font-weight:700;cursor:pointer;font-family:inherit;box-shadow:0 4px 16px var(--glow);transition:all .15s}
.lbtn:hover{box-shadow:0 8px 28px rgba(22,168,95,.3);transform:translateY(-1px)}
.lbtn:disabled{opacity:.6;cursor:not-allowed;transform:none}
.lerr{background:var(--red-bg);border:1px solid var(--red-b);border-radius:var(--r);padding:10px 12px;font-size:12px;color:var(--red);margin-bottom:12px;display:none}
.lpow{text-align:center;margin-top:20px;font-size:11px;color:var(--dim)}
.lpow a{color:var(--g2);font-weight:600}
.lload{text-align:center;font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);padding:10px;display:none;font-family:'DM Mono',monospace}

/* TOAST */
#toast-wrap{position:fixed;bottom:20px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:8px;pointer-events:none}

/* RESPONSIVE */
@media(max-width:760px){
  .g4{grid-template-columns:1fr 1fr}.g3{grid-template-columns:1fr 1fr}.g2{grid-template-columns:1fr}
  .gauto{grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}
  .body{padding:16px 14px}.topnav{display:none}.mobile-topnav{display:flex}
  .hsm{display:none!important}.form-row{grid-template-columns:1fr}
}
@media(max-width:480px){
  .g4,.g3{grid-template-columns:1fr 1fr}.gauto{grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}
  .ptitle{font-size:24px}.sv{font-size:24px}.lcard{padding:28px 20px}
  .ptab{padding:8px 10px;font-size:11px}
}

/* ── SKELETON LOADERS ── */
.skel{
  background:linear-gradient(90deg,var(--bg3) 25%,var(--bg4) 50%,var(--bg3) 75%);
  background-size:200% 100%;
  animation:shimmer 1.2s infinite;
  border-radius:var(--r);
  display:block;
}
@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}
