/* ============================================================
   FastBowlersU PORTAL — SHARED STYLES
   ============================================================ */
:root{
  --green-dark:#161616;--green:#1F1F1F;--green-deep:#0A0A0A;--green-light:#2A2A2A;
  --cream:#EDE6D5;--cream-2:#E5DDC8;--cream-3:#D8CFB8;
  --orange:#962538;--orange-hover:#6E1828;--orange-soft:#C5687A;
  --burgundy:#F2A640;--gold:#F2A640;
  --ink:#1A1A1A;--muted:#6B6B6B;--muted-on-dark:#9A9A9A;
  --white:#FFFFFF;--black:#0B0B0B;
  --red:#B83A3A;--amber:#D4A23A;--green-ok:#2F7D5B;
}
*{box-sizing:border-box;margin:0;padding:0;}
body{font-family:'Inter',system-ui,-apple-system,sans-serif;background:var(--cream);color:var(--ink);line-height:1.5;-webkit-font-smoothing:antialiased;}
a{color:var(--green-deep);}
h1,h2,h3,h4{font-family:'Fraunces',Georgia,serif;color:var(--green-deep);letter-spacing:-0.5px;}
.container{max-width:1200px;margin:0 auto;padding:0 24px;}

/* PORTAL NAV */
.portal-nav{background:var(--green-deep);color:var(--cream);padding:14px 24px;display:flex;align-items:center;gap:24px;flex-wrap:wrap;}
.portal-nav .brand{color:var(--cream);text-decoration:none;font-family:'Fraunces',serif;font-weight:700;font-size:18px;letter-spacing:1px;display:flex;flex-direction:column;line-height:1;}
.portal-nav .brand span{font-family:'Inter',sans-serif;font-size:9px;letter-spacing:2.5px;color:var(--orange-soft);font-weight:600;margin-top:3px;}
.portal-nav .links{display:flex;gap:22px;margin-left:24px;flex:1;flex-wrap:wrap;}
.portal-nav .links a{color:var(--cream);text-decoration:none;font-size:13px;font-weight:500;padding:6px 0;}
.portal-nav .links a:hover,.portal-nav .links a.active{color:var(--orange);}
.portal-nav .links a.active{border-bottom:2px solid var(--orange);}
.portal-nav .user-meta{display:flex;align-items:center;gap:12px;font-size:13px;color:var(--muted-on-dark);}
.portal-nav .user-name{font-weight:600;color:var(--cream);}
.portal-nav .role-pill{font-size:9px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;padding:3px 8px;background:var(--orange);color:var(--green-deep);}
.role-athlete{background:var(--orange-soft);}
.role-coach{background:var(--orange);}
.role-admin{background:var(--burgundy);color:var(--cream);}
.portal-nav #signout-link{color:var(--orange-soft);text-decoration:none;font-size:12px;}
.portal-nav #signout-link:hover{color:var(--orange);}

/* PAGE LAYOUT */
.page-wrap{padding:48px 0;}
.page-head{margin-bottom:36px;}
.page-head .eyebrow{font-size:11px;font-weight:700;letter-spacing:2.5px;color:var(--orange-hover);text-transform:uppercase;margin-bottom:10px;}
.page-head h1{font-size:clamp(30px,4.5vw,44px);margin-bottom:8px;}
.page-head p{font-size:15px;color:var(--muted);max-width:720px;}

/* CARDS */
.card{background:var(--white);border:1px solid var(--cream-3);padding:28px 30px;margin-bottom:18px;}
.card h2{font-size:22px;margin-bottom:6px;}
.card .card-sub{font-size:13px;color:var(--muted);margin-bottom:18px;}
.card.dark{background:var(--green-deep);color:var(--cream);border-color:var(--green-deep);}
.card.dark h2,.card.dark h3{color:var(--cream);}
.card.dark .card-sub{color:var(--muted-on-dark);}

/* BUTTONS */
.btn{display:inline-block;padding:12px 22px;font-family:'Inter',sans-serif;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;font-size:11px;text-decoration:none;cursor:pointer;border:2px solid transparent;transition:all 0.15s ease;background:var(--orange);color:var(--green-deep);}
.btn:hover{background:var(--orange-hover);transform:translateY(-1px);}
.btn:disabled{background:var(--cream-3);color:var(--muted);cursor:not-allowed;transform:none;}
.btn.outline{background:transparent;color:var(--green-deep);border-color:var(--green-deep);}
.btn.outline:hover{background:var(--green-deep);color:var(--cream);}
.btn.dark{background:var(--green-deep);color:var(--cream);}
.btn.dark:hover{background:var(--green);}
.btn.danger{background:var(--burgundy);color:var(--cream);}
.btn.small{padding:8px 14px;font-size:10px;}

/* FORMS */
.field{display:flex;flex-direction:column;gap:6px;margin-bottom:16px;}
.field label{font-size:11px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--green-dark);}
.field input,.field select,.field textarea{padding:11px 14px;border:1px solid var(--cream-3);background:var(--white);font-family:'Inter',sans-serif;font-size:14px;color:var(--ink);width:100%;}
.field textarea{min-height:90px;resize:vertical;font-family:inherit;}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--orange);}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.field-row-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px;}
.help{font-size:12px;color:var(--muted);margin-top:4px;}

/* TABLES */
.table-wrap{background:var(--white);border:1px solid var(--cream-3);overflow-x:auto;}
table.data{width:100%;border-collapse:collapse;font-size:13.5px;}
table.data th{background:var(--cream-2);text-align:left;padding:12px 16px;font-size:11px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--green-dark);border-bottom:1px solid var(--cream-3);}
table.data td{padding:14px 16px;border-bottom:1px solid var(--cream-3);}
table.data tr:hover td{background:var(--cream);}
table.data a{color:var(--green-deep);text-decoration:none;font-weight:600;}
table.data a:hover{color:var(--orange-hover);}

/* SCORE PILLARS */
.score-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;}
.score-card{background:var(--white);border:1px solid var(--cream-3);padding:22px 20px 24px;}
.score-card .pn{font-size:10px;font-weight:700;letter-spacing:2px;color:var(--orange-hover);text-transform:uppercase;margin-bottom:4px;}
.score-card h3{font-size:20px;margin-bottom:14px;}
.score-display{display:flex;align-items:baseline;gap:5px;margin-bottom:10px;}
.score-num{font-family:'Fraunces',serif;font-size:46px;font-weight:600;line-height:1;letter-spacing:-2px;color:var(--green-deep);}
.score-out{font-family:'Fraunces',serif;font-size:16px;color:var(--muted);}
.score-band{font-size:10px;font-weight:700;letter-spacing:2px;text-transform:uppercase;padding:4px 9px;display:inline-block;margin-bottom:10px;}
.score-band.dev{background:rgba(184,58,58,0.12);color:var(--red);}
.score-band.build{background:rgba(212,162,58,0.18);color:#9A7517;}
.score-band.strong{background:rgba(47,125,91,0.14);color:var(--green-ok);}
.score-band.na{background:var(--cream-3);color:var(--muted);}
.score-meter{width:100%;height:5px;background:var(--cream-3);overflow:hidden;}
.score-meter-fill{height:100%;background:var(--orange);transition:width 0.6s ease;}

/* ALERTS */
.alert{padding:14px 18px;margin-bottom:18px;font-size:14px;border-left:4px solid var(--orange);background:rgba(232,154,60,0.08);}
.alert.success{border-color:var(--green-ok);background:rgba(47,125,91,0.08);}
.alert.error{border-color:var(--red);background:rgba(184,58,58,0.08);color:var(--red);}

/* TABS */
.tabs{display:flex;gap:0;border-bottom:1px solid var(--cream-3);margin-bottom:24px;}
.tabs button{background:transparent;border:none;padding:12px 22px;font-family:'Inter',sans-serif;font-size:12px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted);cursor:pointer;border-bottom:3px solid transparent;}
.tabs button.active{color:var(--green-deep);border-bottom-color:var(--orange);}
.tab-panel{display:none;}
.tab-panel.active{display:block;}

/* PARENT CONSENT + SIGNATURE PAD */
.parent-block{background:rgba(232,154,60,0.06);border:1px solid var(--orange-soft);padding:24px 26px;margin:18px 0;}
.parent-block .ttl{font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--orange-hover);margin-bottom:6px;}
.parent-block h3{font-family:'Fraunces',serif;font-size:20px;color:var(--green-deep);margin-bottom:6px;}
.parent-block p.intro{font-size:13.5px;color:var(--muted);margin-bottom:18px;}
.consent-text{background:var(--white);border:1px solid var(--cream-3);padding:16px 18px;margin:12px 0 14px;font-size:13px;line-height:1.55;color:#2C2C2C;}
.consent-text strong{color:var(--green-deep);}
.sig-wrap{border:2px dashed var(--cream-3);background:var(--white);position:relative;}
.sig-canvas{display:block;width:100%;height:170px;cursor:crosshair;touch-action:none;background:var(--white);}
.sig-actions{padding:10px 14px;display:flex;justify-content:space-between;align-items:center;background:var(--cream-2);border-top:1px solid var(--cream-3);}
.sig-hint{font-size:11px;color:var(--muted);letter-spacing:0.3px;}
.sig-clear{background:transparent;border:1px solid var(--cream-3);padding:6px 12px;font-size:10px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--green-deep);cursor:pointer;}
.sig-clear:hover{border-color:var(--orange);color:var(--orange-hover);}
.sig-preview{background:var(--white);border:1px solid var(--cream-3);padding:8px;display:inline-block;max-width:280px;}
.sig-preview img{max-width:100%;display:block;}
.sig-signed-meta{font-size:11px;color:var(--muted);margin-top:6px;letter-spacing:0.3px;}

/* RESPONSIVE */
@media (max-width:780px){
  .portal-nav{padding:12px 16px;gap:14px;}
  .portal-nav .links{order:3;width:100%;margin-left:0;justify-content:flex-start;}
  .score-grid{grid-template-columns:1fr 1fr;}
  .field-row,.field-row-3{grid-template-columns:1fr;}
}
@media (max-width:480px){
  .score-grid{grid-template-columns:1fr;}
}
