/* Bayside Parent Portal — portal.css v2 */
@import url('https://fonts.googleapis.com/css2?family=DM+Sans:wght@300;400;500;600&family=DM+Serif+Display&display=swap');

#bpp-portal *{box-sizing:border-box;margin:0;padding:0;}
#bpp-portal{font-family:'DM Sans',sans-serif;color:#1a1a1a;font-size:14px;
  --red:#C0392B;--red-dk:#922B21;--red-lt:#FDECEA;
  --gold:#D4A017;--gold-lt:#FDF6E3;
  --ink:#1a1a1a;--ink2:#555;--ink3:#888;
  --line:#e8e4e0;--bg:#F9F7F4;--white:#fff;
  --radius:10px;--radius-lg:16px;
}

/* ── LOGIN ── */
.bpp-login-wrap{display:flex;align-items:center;justify-content:center;min-height:560px;padding:2rem;background:var(--bg);}
.bpp-login-box{background:var(--white);border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden;width:100%;max-width:420px;}
.bpp-logo{text-align:center;background:#000;padding:1.75rem 2rem 1.5rem;}
.bpp-logo-img{width:220px;height:auto;display:block;margin:0 auto;}
.bpp-school-sub{font-size:12px;color:rgba(255,255,255,.55);margin-top:6px;letter-spacing:.05em;text-transform:uppercase;}
.bpp-login-body{padding:2rem 2rem 2rem;}
.bpp-school-name{display:none;}
.bpp-hed{font-size:18px;font-weight:600;margin-bottom:4px;}
.bpp-sub{font-size:13px;color:var(--ink2);margin-bottom:1.25rem;}
.bpp-error{background:var(--red-lt);color:var(--red);border:1px solid #f5c6cb;border-radius:8px;padding:10px 12px;font-size:13px;margin-bottom:1rem;}
.bpp-or-link{font-size:13px;color:var(--ink3);text-align:center;margin-top:1rem;}
.bpp-or-link a{color:var(--red);text-decoration:none;font-weight:500;}
.bpp-hed{font-size:18px;font-weight:600;margin-bottom:4px;}
.bpp-sub{font-size:13px;color:var(--ink2);margin-bottom:1.25rem;}
.bpp-error{background:var(--red-lt);color:var(--red);border:1px solid #f5c6cb;border-radius:8px;padding:10px 12px;font-size:13px;margin-bottom:1rem;}
.bpp-or-link{font-size:13px;color:var(--ink3);text-align:center;margin-top:1rem;}
.bpp-or-link a{color:var(--red);text-decoration:none;font-weight:500;}

/* ── FIELDS ── */
.bpp-field{margin-bottom:.9rem;}
.bpp-field label{display:block;font-size:12px;font-weight:500;color:var(--ink2);margin-bottom:4px;}
.bpp-field input,.bpp-field select,.bpp-field textarea{width:100%;padding:9px 12px;border:1px solid var(--line);border-radius:var(--radius);font-family:'DM Sans',sans-serif;font-size:13px;color:var(--ink);background:var(--white);}
.bpp-field input:focus,.bpp-field select:focus,.bpp-field textarea:focus{outline:none;border-color:var(--red);}
.bpp-field textarea{resize:vertical;min-height:72px;}

/* ── BUTTONS ── */
.bpp-btn-red{width:100%;padding:11px;background:var(--red);color:#fff;border:none;border-radius:var(--radius);font-family:'DM Sans',sans-serif;font-size:14px;font-weight:600;cursor:pointer;}
.bpp-btn-red:hover{background:var(--red-dk);}
.bpp-btn-sm{padding:8px 16px;border-radius:var(--radius);font-family:'DM Sans',sans-serif;font-size:13px;font-weight:600;cursor:pointer;border:none;width:auto;}
.bpp-edit-btn{font-size:12px;color:#B8860B;cursor:pointer;font-weight:600;border:1px solid #B8860B;border-radius:6px;padding:4px 12px;background:var(--white);}
.bpp-empty{font-size:13px;color:var(--ink3);}

/* ── NAV ── */
.bpp-topnav{background:#000;border-bottom:2px solid #B8860B;display:flex;align-items:center;justify-content:space-between;padding:0 1.5rem;height:64px;}
.bpp-brand{display:flex;align-items:center;}
.bpp-nav-logo{height:44px;width:auto;object-fit:contain;display:block;}
.bpp-nav-title{display:none;}
.bpp-nav-sub{display:none;}
.bpp-nav-right{display:flex;align-items:center;gap:10px;}
.bpp-user-pill{display:flex;align-items:center;gap:8px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15);border-radius:999px;padding:4px 12px 4px 6px;font-size:13px;font-weight:500;color:#fff;}
.bpp-avatar{width:26px;height:26px;border-radius:50%;background:#B8860B;color:#fff;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;}
.bpp-signout{font-size:12px;color:rgba(255,255,255,.6);text-decoration:none;border:1px solid rgba(255,255,255,.2);border-radius:6px;padding:4px 10px;background:transparent;}
.bpp-signout:hover{color:#fff;border-color:rgba(255,255,255,.5);}

/* ── BANNER ── */
.bpp-banner{background:#111;color:#fff;padding:1.25rem 1.5rem;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid #333;}
.bpp-banner-title{font-family:'DM Serif Display',serif;font-size:22px;color:#D4A017;}
.bpp-banner-sub{font-size:13px;opacity:.7;margin-top:2px;}
.bpp-banner-badge{background:rgba(180,130,0,.25);border:1px solid rgba(180,130,0,.4);border-radius:999px;padding:6px 14px;font-size:13px;font-weight:600;color:#D4A017;}
.bpp-banner-badge-ok{background:rgba(39,174,96,.15);border:1px solid rgba(39,174,96,.3);color:#27ae60;}

/* ── TABS ── */
.bpp-tabs{background:var(--white);border-bottom:2px solid var(--line);display:flex;padding:0 2rem;overflow-x:auto;gap:4px;}
.bpp-tab{padding:18px 24px;font-size:15px;font-weight:600;color:var(--ink3);cursor:pointer;border-bottom:3px solid transparent;transition:all .15s;white-space:nowrap;letter-spacing:-.01em;margin-bottom:-2px;}
.bpp-tab:hover{color:var(--ink);background:rgba(0,0,0,.03);border-radius:8px 8px 0 0;}
.bpp-tab.active{color:#B8860B;border-bottom:3px solid #B8860B;font-weight:700;}
.bpp-tab-content{padding:2rem;background:var(--bg);}

/* ── CARDS ── */
.bpp-card{background:var(--white);border:1px solid var(--line);border-radius:var(--radius-lg);padding:1.25rem;margin-bottom:0;}
.bpp-card-hed{font-size:15px;font-weight:600;margin-bottom:1rem;display:flex;align-items:center;justify-content:space-between;}
.bpp-mt{margin-top:1rem;}
.bpp-mt-sm{margin-top:.5rem;}
.bpp-full{grid-column:1/-1;}

/* ── OVERVIEW METRICS ── */
.bpp-metric-strip{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin-bottom:1.25rem;}
.bpp-metric{background:var(--white);border:1px solid var(--line);border-radius:var(--radius-lg);padding:1rem 1.25rem;}
.bpp-metric-label{font-size:12px;color:var(--ink3);margin-bottom:4px;}
.bpp-metric-val{font-size:26px;font-weight:700;color:var(--ink);}
.bpp-metric-sm{font-size:18px;padding-top:4px;}
.bpp-metric-sub{font-size:12px;color:var(--ink3);margin-top:3px;}
.bpp-red{color:var(--red);}
.bpp-green{color:#27ae60;}

/* ── INVOICE ROWS ── */
.bpp-inv-row{display:flex;align-items:flex-start;justify-content:space-between;padding:10px 0;border-bottom:1px solid var(--line);}
.bpp-inv-row:last-child{border-bottom:none;}
.bpp-inv-name{font-size:13px;font-weight:500;}
.bpp-inv-child{font-weight:400;color:var(--ink3);}
.bpp-inv-date{font-size:12px;color:var(--ink3);margin-top:2px;}
.bpp-inv-right{display:flex;align-items:center;gap:8px;flex-shrink:0;margin-left:8px;}
.bpp-inv-amt{font-size:14px;font-weight:600;}

/* ── UPCOMING CLASSES ── */
.bpp-class-row{display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid var(--line);}
.bpp-class-row:last-child{border-bottom:none;}
.bpp-class-dot{width:8px;height:8px;border-radius:50%;background:var(--red);flex-shrink:0;}
.bpp-class-info{flex:1;}
.bpp-class-label{font-size:13px;font-weight:500;}
.bpp-class-meta{font-size:12px;color:var(--ink3);margin-top:2px;}
.bpp-class-req-btn{font-size:11px;font-weight:600;color:var(--red);border:1px solid var(--red);border-radius:6px;padding:4px 10px;background:var(--white);cursor:pointer;flex-shrink:0;white-space:nowrap;}
.bpp-class-req-btn:hover{background:var(--red-lt);}

/* ── CHILD PILLS (overview) ── */
.bpp-child-pill{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid var(--line);}
.bpp-child-pill:last-child{border-bottom:none;}
.bpp-child-av{width:32px;height:32px;border-radius:50%;background:var(--red);color:#fff;font-size:14px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.bpp-child-name{font-size:13px;font-weight:600;}
.bpp-child-meta{font-size:12px;color:var(--ink3);}

/* ── DOJO CARD ── */
.bpp-dojo-card{text-align:center;padding:1.5rem 1.25rem;}
.bpp-dojo-icon{font-size:28px;margin-bottom:8px;}
.bpp-dojo-title{font-size:15px;font-weight:600;margin-bottom:4px;}
.bpp-dojo-sub{font-size:13px;color:var(--ink2);}

/* ── ALERT CARD ── */
.bpp-alert-card{border-color:#f5c6cb;background:var(--red-lt);}
.bpp-alert-title{font-size:14px;font-weight:600;color:var(--red);}
.bpp-alert-sub{font-size:13px;color:var(--ink2);margin-top:4px;}

/* ── TWO / THREE COL LAYOUTS ── */
.bpp-two-col{display:grid;grid-template-columns:minmax(0,1.4fr) minmax(0,1fr);gap:1rem;}
.bpp-three-col{display:grid;grid-template-columns:minmax(0,1.6fr) minmax(0,1fr);gap:1rem;}
.bpp-terms-left,.bpp-terms-right{display:flex;flex-direction:column;gap:1rem;}
@media(max-width:680px){.bpp-two-col,.bpp-three-col{grid-template-columns:1fr;}}

/* ── ENROLMENT DETAIL VIEW ── */
.bpp-detail-section{font-size:11px;font-weight:600;color:var(--ink3);letter-spacing:.06em;text-transform:uppercase;padding:4px 0;border-bottom:1px solid var(--line);margin:1rem 0 .6rem;}
.bpp-detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px 16px;}
.bpp-dl{font-size:11px;color:var(--ink3);margin-bottom:2px;}
.bpp-dv{font-size:14px;font-weight:500;}
.bpp-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
.bpp-form-section{font-size:11px;font-weight:600;color:var(--ink3);letter-spacing:.06em;text-transform:uppercase;padding:4px 0;border-bottom:1px solid var(--line);margin:.5rem 0 .25rem;grid-column:1/-1;}
.bpp-save-bar{display:flex;align-items:center;justify-content:space-between;padding:10px 0 0;border-top:1px solid var(--line);margin-top:1rem;}
.bpp-save-note{font-size:12px;color:var(--ink3);}

/* ── CHILD CARDS ── */
.bpp-child-card{margin-bottom:1rem;}
.bpp-child-card-head{display:flex;align-items:center;gap:10px;margin-bottom:.75rem;}
.bpp-child-card-av{width:38px;height:38px;border-radius:50%;background:var(--red);color:#fff;font-size:16px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.bpp-child-card-name{font-size:15px;font-weight:600;}
.bpp-child-card-meta{font-size:12px;color:var(--ink3);}
.bpp-child-card-head .bpp-edit-btn{margin-left:auto;}
.bpp-add-child-btn{font-size:12px;}

/* ── TERMS ── */
.bpp-term-card{background:var(--white);border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden;}
.bpp-term-head{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;}
.bpp-term-name{font-size:15px;font-weight:600;}
.bpp-term-dates{font-size:12px;color:var(--ink3);margin-top:2px;}
.bpp-term-body{padding:12px 16px;background:var(--bg);border-top:1px solid var(--line);}
.bpp-term-row{display:flex;justify-content:space-between;font-size:13px;padding:3px 0;}
.bpp-tl{color:var(--ink3);}
.bpp-tv{font-weight:500;}
.bpp-price{color:var(--red);font-weight:700;}
.bpp-term-section-label{font-size:11px;font-weight:600;color:var(--ink3);letter-spacing:.05em;text-transform:uppercase;margin:10px 0 6px;padding-top:10px;border-top:1px solid var(--line);}
.bpp-child-pay-row{display:flex;align-items:center;justify-content:space-between;padding:5px 0;}
.bpp-child-pay-name{font-size:13px;font-weight:500;}
.bpp-pay-btn{padding:6px 12px;background:var(--red);color:#fff;border:none;border-radius:var(--radius);font-size:12px;font-weight:600;cursor:pointer;}
.bpp-preenrol-btn{padding:6px 12px;background:var(--gold-lt);color:var(--ink);border:1px solid var(--gold);border-radius:var(--radius);font-size:12px;font-weight:600;cursor:pointer;}

/* ── PAYMENT SUMMARY ── */
.bpp-sum-row{display:flex;justify-content:space-between;align-items:center;padding:6px 0;border-bottom:1px solid var(--line);}
.bpp-sum-row:last-child{border-bottom:none;}
.bpp-sum-label{font-size:13px;color:var(--ink3);}
.bpp-sum-total{display:flex;justify-content:space-between;font-size:14px;font-weight:600;margin-top:10px;padding-top:10px;border-top:1px solid var(--line);}
.bpp-how-pay p{font-size:13px;color:var(--ink2);line-height:1.7;margin-bottom:10px;}

/* ── BADGES ── */
.bpp-badge{display:inline-flex;align-items:center;font-size:11px;font-weight:600;padding:3px 10px;border-radius:999px;}
.bpp-b-paid{background:#e8f5e9;color:#2e7d32;}
.bpp-b-due{background:#fff3e0;color:#e65100;}
.bpp-b-over{background:#ffebee;color:#c62828;}
.bpp-b-conf{background:#e3f2fd;color:#1565c0;}
.bpp-b-upcoming{background:#e3f2fd;color:#1565c0;}
.bpp-b-grey{background:#f5f5f5;color:#888;}

/* ── PARENT REQUESTS ── */
.bpp-req-type-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:1.25rem;}
.bpp-req-type{border:1px solid var(--line);border-radius:var(--radius);padding:12px;cursor:pointer;transition:all .12s;}
.bpp-req-type:hover,.bpp-req-type.active{border-color:var(--red);background:var(--red-lt);}
.bpp-rt-icon{font-size:18px;margin-bottom:4px;}
.bpp-rt-label{font-size:13px;font-weight:600;}
.bpp-rt-sub{font-size:11px;color:var(--ink3);margin-top:2px;}
.bpp-req-item{display:flex;align-items:flex-start;gap:10px;padding:10px 0;border-bottom:1px solid var(--line);}
.bpp-req-item:last-child{border-bottom:none;}
.bpp-req-dot{width:8px;height:8px;border-radius:50%;margin-top:5px;flex-shrink:0;}
.bpp-ri-title{font-size:13px;font-weight:500;}
.bpp-ri-date{font-size:11px;color:var(--ink3);margin-top:2px;}
.bpp-ri-weeks{font-size:11px;color:#1565c0;margin-top:3px;}
.bpp-ri-status{font-size:11px;font-weight:600;margin-top:3px;}
.bpp-admin-reply{font-size:12px;background:#f5f5f5;border-radius:6px;padding:6px 8px;margin-top:6px;color:var(--ink2);}

/* ── MAKEUP WEEK PICKER ── */
.bpp-makeup-intro{font-size:13px;color:var(--ink2);margin-bottom:.75rem;background:var(--bg);border:1px solid var(--line);border-radius:var(--radius);padding:10px 12px;}
.bpp-week-picker{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:1rem;}
.bpp-week-btn{border:1px solid var(--line);border-radius:var(--radius);padding:10px 12px;cursor:pointer;transition:all .12s;background:var(--white);}
.bpp-week-btn:not(.bpp-week-past):hover{border-color:var(--red);background:var(--red-lt);}
.bpp-week-btn.selected{border-color:var(--red);background:var(--red-lt);border-width:2px;}
.bpp-week-past{opacity:.45;cursor:not-allowed;background:var(--bg);}
.bpp-week-num{font-size:11px;font-weight:700;color:var(--red);text-transform:uppercase;letter-spacing:.05em;margin-bottom:2px;}
.bpp-week-past .bpp-week-num{color:var(--ink3);}
.bpp-week-date{font-size:13px;font-weight:600;color:var(--ink);}
.bpp-week-time{font-size:12px;color:var(--ink3);margin-top:2px;}
.bpp-week-loc{font-size:11px;color:var(--ink3);}

/* ── PAYMENT MODAL ── */
#bpp-pay-modal{position:fixed;inset:0;z-index:9999;display:flex;align-items:center;justify-content:center;padding:1rem;}
.bpp-modal-overlay{position:absolute;inset:0;background:rgba(0,0,0,.5);}
.bpp-modal-box{position:relative;background:var(--white);border-radius:var(--radius-lg);padding:2rem;width:100%;max-width:420px;max-height:90vh;overflow-y:auto;z-index:1;}
.bpp-modal-hed{display:flex;align-items:center;justify-content:space-between;margin-bottom:.25rem;}
.bpp-modal-hed h3{font-size:18px;font-weight:600;}
.bpp-modal-close{background:none;border:none;font-size:20px;cursor:pointer;color:var(--ink3);}
.bpp-modal-sub{font-size:13px;color:var(--ink3);margin-bottom:1.25rem;}
.bpp-pay-methods{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:1.25rem;}
.bpp-pay-method{border:1px solid var(--line);border-radius:var(--radius);padding:12px 8px;cursor:pointer;text-align:center;transition:all .12s;}
.bpp-pay-method:hover,.bpp-pay-method.active{border-color:var(--red);background:var(--red-lt);}
.bpp-pm-icon{font-size:20px;margin-bottom:4px;}
.bpp-pm-label{font-size:12px;font-weight:600;}
.bpp-method-detail{margin-bottom:1rem;}
.bpp-bank-box{background:var(--bg);border:1px solid var(--line);border-radius:var(--radius);padding:14px;margin-bottom:8px;}
.bpp-bank-row{display:flex;justify-content:space-between;align-items:center;padding:5px 0;border-bottom:1px solid var(--line);font-size:13px;}
.bpp-bank-row:last-child{border-bottom:none;}
.bpp-bank-label{color:var(--ink3);font-size:12px;}
.bpp-bank-val{font-weight:600;display:flex;align-items:center;gap:8px;}
.bpp-copy-btn{font-size:10px;color:var(--red);cursor:pointer;border:1px solid var(--red);border-radius:4px;padding:2px 6px;font-weight:600;}
.bpp-bank-note{font-size:12px;color:var(--ink3);}
.bpp-info-box{background:var(--bg);border:1px solid var(--line);border-radius:var(--radius);padding:14px;font-size:13px;color:var(--ink2);line-height:1.7;}
.bpp-stripe-note{text-align:center;font-size:11px;color:var(--ink3);margin-top:10px;}
.bpp-check-circle{width:60px;height:60px;border-radius:50%;background:#e8f5e9;margin:0 auto 1rem;display:flex;align-items:center;justify-content:center;font-size:26px;color:#2e7d32;}

/* ── ENROLMENT FORM IMPROVEMENTS ── */
.bpp-form-section-heading{font-size:13px;font-weight:700;color:var(--ink);letter-spacing:.04em;text-transform:uppercase;padding:6px 0;border-bottom:2px solid var(--red);margin:1.25rem 0 .75rem;grid-column:1/-1;}
.bpp-form-intro{font-size:13px;color:var(--ink2);margin-bottom:1rem;line-height:1.6;grid-column:1/-1;}
.bpp-required{color:var(--red);font-size:13px;}
.bpp-level-hint{font-size:11px;color:var(--ink3);margin-bottom:4px;}
.bpp-consent-hint{font-size:12px;color:var(--ink2);margin-bottom:6px;line-height:1.5;}
