:root{
  --ink:#1B2A4A;
  --ink-soft:#2A3D63;
  --paper:#FAF7EF;
  --paper-dim:#F1ECDE;
  --chalk:#F2C14E;
  --coral:#E1553F;
  --sage:#3F9066;
  --slate:#4A5063;
  --line: rgba(27,42,74,.14);
  --radius: 14px;
  --filter-pos: left;
  --filter-color: var(--coral);
  --logo-font: 'Fraunces', serif;
}
*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  font-family:'Work Sans',sans-serif;
  color:var(--ink);
  background:var(--paper);
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3,h4{font-family:'Fraunces',serif; margin:0; line-height:1.05;}
p{margin:0; color:var(--slate); line-height:1.55;}
a{color:inherit; text-decoration:none;}
.mono{font-family:'Space Mono',monospace;}
img{max-width:100%; display:block;}
button{font-family:inherit; cursor:pointer;}
.wrap{max-width:1180px; margin:0 auto; padding:0 22px;}
.eyebrow{font-family:'Space Mono',monospace; text-transform:uppercase; letter-spacing:.14em; font-size:12px; color:var(--coral); font-weight:700;}

/* ===== TOPBAR (two-row, doesn't collapse early) ===== */
.topbar{position:sticky; top:0; z-index:80; box-shadow:0 2px 14px rgba(0,0,0,.12);}
.topbar-utility{
  background:var(--ink-soft); color:rgba(250,247,239,.85);
  border-bottom:1px solid rgba(250,247,239,.12);
}
.topbar-utility .wrap{display:flex; justify-content:space-between; align-items:center; padding:7px 22px; font-size:12.5px;}
.topbar-utility .u-left{display:flex; gap:18px;}
.topbar-utility .u-left span{opacity:.85;}
.topbar-utility a{opacity:.9;}
.topbar-utility a:hover{opacity:1; text-decoration:underline;}

.topbar-main{background:var(--ink); border-bottom:3px solid var(--chalk);}
.topbar-inner{display:flex; align-items:center; justify-content:space-between; padding:12px 22px; max-width:1180px; margin:0 auto; gap:14px;}
.logo{display:flex; align-items:center; gap:10px; font-family:var(--logo-font); font-weight:700; font-size:22px; color:var(--paper);}
.logo .mark{width:34px;height:34px;border-radius:8px;background:var(--chalk); color:var(--ink); display:flex;align-items:center;justify-content:center; font-family:'Space Mono',monospace; font-weight:700; transform:rotate(-6deg); overflow:hidden;}
.logo .mark img{width:100%; height:100%; object-fit:cover;}

.nav{display:flex; align-items:center; gap:20px; flex-wrap:nowrap;}
.nav a{font-size:14px; font-weight:500; opacity:.9; padding:6px 2px; border-bottom:2px solid transparent; transition:.15s; white-space:nowrap; color:var(--paper);}
.nav a:hover, .nav a.active{opacity:1; border-color:var(--chalk); color:var(--paper);}

.topbar-right{display:flex; align-items:center; gap:10px; flex-shrink:0;}
.role-pill{
  font-family:'Space Mono',monospace; font-size:11px; color:var(--paper);
  background:rgba(242,193,78,.14); border:1px solid var(--chalk); padding:6px 10px; border-radius:20px; display:flex; align-items:center; gap:8px;
}
.role-pill select{background:transparent; color:var(--chalk); border:none; font-family:inherit; font-size:11px; font-weight:700;}
.role-pill select option{color:var(--ink); background:var(--paper);}
.lead-chip{display:flex; gap:10px; align-items:center; font-family:'Space Mono',monospace; font-size:11.5px; background:rgba(242,193,78,.16); border:1px solid var(--chalk); padding:6px 10px; border-radius:20px; color:var(--paper);}
.lead-chip b{color:var(--chalk);}

.btn{display:inline-flex; align-items:center; gap:8px; padding:10px 18px; border-radius:30px; font-weight:700; font-size:14px; border:2px solid transparent; transition:.15s; white-space:nowrap;}
.btn-primary{background:var(--coral); color:#fff;}
.btn-primary:hover{background:#c8452f;}
.btn-chalk{background:var(--chalk); color:var(--ink); border-color:var(--chalk);}
.btn-chalk:hover{background:#e0ac2f;}
.btn-outline{border-color:var(--paper); color:var(--paper); background:transparent;}
.btn-outline:hover{background:rgba(250,247,239,.12);}
.btn-dark{background:var(--ink); color:var(--paper);}
.btn-ghost{background:transparent; color:var(--ink); border-color:var(--line);}
.btn-sm{padding:8px 14px; font-size:12.5px;}
.btn[disabled]{opacity:.5; cursor:not-allowed;}

.hamburger{display:none; background:none; border:none; color:var(--paper); font-size:24px; cursor:pointer;}
.nav-mobile-head, .nav-mobile-foot, .nav-mobile-social{display:none;}
.msg-label{display:inline;}

/* mobile right-side drawer */
.drawer-overlay{display:none; position:fixed; inset:0; background:rgba(0,0,0,.45); z-index:79;}
.drawer-overlay.open{display:block;}
@media(max-width:1100px){
  .nav{
    position:fixed; top:0; right:0; bottom:0; left:auto; width:78%; max-width:300px; z-index:96;
    background:var(--ink); flex-direction:column; align-items:flex-start; gap:2px;
    padding:0 22px 22px; transform:translateX(105%); transition:.28s ease; overflow-y:auto;
    box-shadow:-6px 0 30px rgba(0,0,0,.3);
  }
  .nav.open{transform:translateX(0);}
  .nav a{padding:12px 0; border-bottom:1px solid rgba(250,247,239,.1); width:100%;}
  .nav-mobile-head{
  display:flex; justify-content:space-between; align-items:center; width:100%;
  padding:18px 0 12px; color:var(--paper); font-family:'Space Mono',monospace; font-size:12px; text-transform:uppercase; letter-spacing:.05em;
}
.nav-mobile-head button{background:none; border:none; color:var(--paper); font-size:18px; cursor:pointer;}
.nav-mobile-brand{display:flex; align-items:center; gap:10px;}
.nav-mobile-brand .mark{width:32px; height:32px; font-size:13px;}
.nav-mobile-brand .brand-name{font-family:var(--logo-font); font-weight:700; font-size:16px; color:var(--paper); text-transform:none; letter-spacing:0;}
.nav-mobile-info{width:100%; padding-bottom:14px; margin-bottom:8px; border-bottom:1px solid rgba(250,247,239,.15); font-size:12px; color:rgba(250,247,239,.75); font-family:'Space Mono',monospace;}
.nav-mobile-info div{padding:3px 0;}
.nav-mobile-info b{color:var(--chalk);}
.nav-mobile-foot{display:block; width:100%; margin-top:16px; padding-top:16px; border-top:1px solid rgba(250,247,239,.15);}
.nav-mobile-social{display:flex; width:100%; justify-content:center; gap:20px; margin-top:16px; padding-top:16px; border-top:1px solid rgba(250,247,239,.15); font-size:22px;}
.nav-mobile-social a{opacity:.85;}
.social-icons-desktop{display:none;}
  .hamburger{display:block;}
  .desktop-only-cta{display:none;}
}
@media(min-width:1101px){
  .social-icons-desktop{display:flex; gap:14px; align-items:center; font-size:15px;}
  .social-icons-desktop a{opacity:.85; text-decoration:none;}
  .social-icons-desktop a:hover{opacity:1;}
}
@media(max-width:640px){
  .topbar-utility{display:none;}
  .msg-label{display:none;}
}

/* ===== BUTTONS/CARDS shared ===== */
section{padding:56px 0;}
.section-head{display:flex; align-items:flex-end; justify-content:space-between; gap:20px; margin-bottom:32px; flex-wrap:wrap;}
.section-head h2{font-size:clamp(24px,3.4vw,36px);}

.card-basic{background:#fff; border:1px solid var(--line); border-radius:var(--radius); padding:22px;}

/* filter */
.finder{background:var(--paper-dim); border-top:1px solid var(--line); border-bottom:1px solid var(--line);}
.finder-grid{display:grid; grid-template-columns:280px 1fr; gap:28px; align-items:start;}
.filter-panel{background:#fff; border:1px solid var(--line); border-radius:var(--radius); padding:20px; position:sticky; top:120px;}
.filter-panel h4{font-size:15px; display:flex; align-items:center; justify-content:space-between;}
.filter-group{margin-top:16px;}
.filter-group label{display:block; font-size:12px; font-weight:600; text-transform:uppercase; letter-spacing:.05em; color:var(--slate); margin-bottom:6px;}
select, input[type=text], input[type=email], input[type=tel], input[type=password], textarea{
  width:100%; padding:10px 12px; border-radius:8px; border:1px solid var(--line); background:var(--paper); font-family:'Work Sans'; font-size:14px; color:var(--ink);
}
textarea{resize:vertical;}
.tag-check{display:flex; flex-wrap:wrap; gap:6px; margin-top:6px;}
.tag-check span, .tag-check label{font-size:12px; padding:6px 10px; border-radius:20px; border:1px solid var(--line); background:var(--paper); cursor:pointer; transition:.15s; display:inline-flex; align-items:center; gap:5px;}
.tag-check span.on, .tag-check label.on{background:var(--ink); color:var(--paper); border-color:var(--ink);}
.filter-apply{width:100%; margin-top:18px;}

.filter-fab{display:none; position:fixed; bottom:26px; z-index:60; background:var(--filter-color); color:#fff; width:54px; height:54px; border-radius:50%; align-items:center; justify-content:center; font-size:22px; box-shadow:0 10px 24px rgba(0,0,0,.25); border:none;}
.filter-fab.left{left:18px;} .filter-fab.right{right:18px;}
.filter-overlay{display:none; position:fixed; inset:0; background:rgba(0,0,0,.4); z-index:89;}
.filter-overlay.open{display:block;}
.filter-clear{font-size:11.5px; color:var(--coral); font-weight:600; background:none; border:none; cursor:pointer; padding:0;}
@media(max-width:980px){
  .finder-grid{grid-template-columns:1fr;}
  .filter-panel{position:fixed; top:0; bottom:0; left:0; width:82%; max-width:320px; border-radius:0; z-index:90; transform:translateX(-105%); transition:.25s; overflow-y:auto;}
  .filter-panel.open{transform:translateX(0);}
  .filter-fab{display:flex;}
}

/* tutor grid + id card */
.tutor-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:22px;}
.tcard{background:#fff; border-radius:18px; border:1px solid var(--line); overflow:hidden; position:relative; transition:.2s;}
.tcard:hover{transform:translateY(-4px); box-shadow:0 16px 30px rgba(27,42,74,.12);}
.tcard-top{background:var(--ink); padding:18px; display:flex; gap:14px; align-items:center; position:relative;}
.tcard-top::after{content:""; position:absolute; left:0; right:0; bottom:-9px; height:18px; background:radial-gradient(circle,transparent 9px, var(--paper) 9.5px) repeat-x; background-size:22px 18px;}
.avatar{width:58px;height:58px;border-radius:50%; display:flex; align-items:center; justify-content:center; font-family:'Space Mono',monospace; font-weight:700; color:#fff; font-size:18px; flex-shrink:0; border:2px solid rgba(255,255,255,.5);}
.avatar.big{width:76px;height:76px;font-size:24px;}
.avatar.small-40{width:40px;height:40px;font-size:14px;}
.tcard-top .who .nm{font-family:'Fraunces',serif; font-weight:600; font-size:18px; color:var(--paper);}
.tcard-top .who .loc{font-size:12px; color:rgba(250,247,239,.7); margin-top:2px;}
.verified{position:absolute; top:12px; right:12px; background:var(--chalk); color:var(--ink); font-family:'Space Mono',monospace; font-size:9.5px; font-weight:700; padding:4px 8px; border-radius:5px; transform:rotate(4deg);}
.tcard-body{padding:22px 18px 18px;}
.mode-badge{display:inline-block; font-size:11px; font-family:'Space Mono',monospace; padding:4px 9px; border-radius:6px; margin-bottom:12px; background:rgba(63,144,102,.12); color:var(--sage); font-weight:700;}
.tcard-body .about{font-size:13.5px; margin-bottom:14px; min-height:38px;}
.tag-row{display:flex; flex-wrap:wrap; gap:6px; margin-bottom:8px;}
.tag-row .t{font-size:11px; background:var(--paper-dim); border:1px solid var(--line); padding:4px 9px; border-radius:6px; color:var(--ink-soft);}
.tcard-meta{display:flex; justify-content:space-between; align-items:center; margin-top:16px; padding-top:14px; border-top:1px dashed var(--line);}
.rate{font-family:'Space Mono',monospace; font-weight:700; font-size:16px;}
.rate span{font-size:11px; color:var(--slate); font-weight:400;}
.view-btn{padding:9px 16px; border-radius:30px; background:var(--ink); color:#fff; font-size:13px; font-weight:600; border:none;}
@media(max-width:980px){.tutor-grid{grid-template-columns:repeat(2,1fr);}}
@media(max-width:640px){.tutor-grid{grid-template-columns:1fr;}}

/* modal */
.modal-overlay{display:none; position:fixed; inset:0; background:rgba(27,42,74,.55); z-index:100; align-items:flex-start; justify-content:center; padding:40px 16px; overflow-y:auto;}
.modal-overlay.open{display:flex;}
.modal{background:var(--paper); max-width:640px; width:100%; border-radius:20px; overflow:hidden; position:relative; box-shadow:0 30px 60px rgba(0,0,0,.3);}
.modal-close{position:absolute; top:16px; right:16px; background:rgba(255,255,255,.15); color:#fff; border:none; width:34px; height:34px; border-radius:50%; font-size:18px; z-index:2;}
.modal-head{background:var(--ink); color:var(--paper); padding:32px 28px 44px; position:relative;}
.modal-head::after{content:""; position:absolute; left:0; right:0; bottom:-11px; height:22px; background:radial-gradient(circle,transparent 11px, var(--paper) 11.5px) repeat-x; background-size:26px 22px;}
.modal-head .row{display:flex; gap:18px; align-items:center;}
.modal-head .avatar{width:76px;height:76px; font-size:24px;}
.modal-head .nm{font-size:24px; color:var(--paper);}
.modal-head .loc{font-size:13px; color:rgba(250,247,239,.75); margin-top:4px;}
.modal-body{padding:30px 28px 28px;}
.mgrid{display:grid; grid-template-columns:1fr 1fr; gap:18px; margin-bottom:22px;}
.mfield{font-size:13px;}
.mfield label{display:block; font-family:'Space Mono',monospace; font-size:10.5px; text-transform:uppercase; letter-spacing:.06em; color:var(--coral); margin-bottom:4px;}
.blur-line{filter:blur(4px); user-select:none;}
.unlock-box{background:var(--paper-dim); border:1px dashed var(--line); border-radius:12px; padding:16px; display:flex; align-items:center; justify-content:space-between; gap:14px; margin-top:6px; flex-wrap:wrap;}
.unlock-box p{font-size:13px; max-width:320px;}
.about-block{background:#fff; border:1px solid var(--line); border-radius:12px; padding:16px; margin-top:6px; font-size:14px;}
@media(max-width:640px){.mgrid{grid-template-columns:1fr;}}

/* pricing */
.pricing-grid{display:grid; grid-template-columns:repeat(4,1fr); gap:20px;}
.plan{background:#fff; border:1px solid var(--line); border-radius:var(--radius); padding:26px 22px; position:relative;}
.plan.popular{border-color:var(--coral); box-shadow:0 14px 30px rgba(225,85,63,.14);}
.plan.popular .pop-tag{position:absolute; top:-12px; left:22px; background:var(--coral); color:#fff; font-size:10.5px; font-family:'Space Mono',monospace; padding:4px 10px; border-radius:20px;}
.plan .price{font-family:'Fraunces',serif; font-size:34px; font-weight:700; margin:14px 0 2px;}
.plan .per{font-size:12px; color:var(--slate);}
.plan ul{list-style:none; padding:0; margin:18px 0; font-size:13.5px;}
.plan li{padding:6px 0; border-top:1px dashed var(--line); display:flex; gap:8px;}
.plan li:first-child{border-top:none;}
.topup-note{margin-top:34px; background:var(--paper-dim); border:1px solid var(--line); border-radius:var(--radius); padding:20px 24px; display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:14px;}
.coupon-ticker{margin-top:18px; background:var(--ink); color:var(--chalk); border-radius:10px; padding:10px 0; overflow:hidden; white-space:nowrap; font-family:'Space Mono',monospace; font-size:13px;}
.coupon-ticker .track{display:inline-block; padding-left:100%; animation:scroll-left 18s linear infinite;}
@keyframes scroll-left{0%{transform:translateX(0);}100%{transform:translateX(-100%);}}
@media(max-width:980px){.pricing-grid{grid-template-columns:repeat(2,1fr);}}
@media(max-width:640px){.pricing-grid{grid-template-columns:1fr;}}

/* materials */
.mat-grid{display:grid; grid-template-columns:repeat(4,1fr); gap:18px;}
.mat-card{background:#fff; border:1px solid var(--line); border-radius:14px; overflow:hidden;}
.mat-thumb{height:110px; background:linear-gradient(135deg,var(--ink),var(--ink-soft)); display:flex; align-items:center; justify-content:center; color:var(--chalk); font-family:'Fraunces',serif; font-size:15px; text-align:center; padding:10px;}
.mat-info{padding:14px;}
.mat-info .price{font-family:'Space Mono',monospace; font-weight:700; color:var(--coral);}
@media(max-width:980px){.mat-grid{grid-template-columns:repeat(2,1fr);}}
@media(max-width:640px){.mat-grid{grid-template-columns:1fr;}}

/* forms */
.form-shell{max-width:640px; margin:0 auto; background:#fff; border:1px solid var(--line); border-radius:18px; padding:34px;}
.form-grid{display:grid; grid-template-columns:1fr 1fr; gap:16px;}
.form-grid.full, .field-full{grid-column:1/-1;}
.field label{display:block; font-size:12.5px; font-weight:600; margin-bottom:6px; color:var(--ink-soft);}
.field{margin-bottom:4px;}
@media(max-width:640px){.form-grid{grid-template-columns:1fr;}}

/* footer */
footer{background:var(--ink); color:rgba(250,247,239,.7); padding:44px 0 24px; margin-top:20px;}
.foot-grid{display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:24px;}
.foot-grid h5{color:var(--paper); font-family:'Space Mono',monospace; font-size:12px; text-transform:uppercase; letter-spacing:.08em; margin-bottom:12px;}
.foot-grid a{display:block; font-size:13.5px; padding:4px 0; opacity:.85;}
.foot-bottom{border-top:1px solid rgba(250,247,239,.12); margin-top:30px; padding-top:18px; font-size:12px; display:flex; justify-content:space-between; flex-wrap:wrap; gap:8px;}
@media(max-width:820px){.foot-grid{grid-template-columns:1fr 1fr;}}
@media(max-width:640px){.foot-grid{grid-template-columns:1fr;}}

/* dashboards */
.dash-shell{display:grid; grid-template-columns:230px 1fr; min-height:70vh;}
.dash-side{background:var(--ink); color:var(--paper); padding:24px 16px;}
.dash-side .d-user{display:flex; gap:10px; align-items:center; margin-bottom:20px; padding-bottom:16px; border-bottom:1px solid rgba(250,247,239,.14);}
.dash-side nav a{display:flex; align-items:center; gap:10px; font-size:13.5px; padding:10px 12px; border-radius:8px; margin-bottom:4px; opacity:.85; cursor:pointer;}
.dash-side nav a.active, .dash-side nav a:hover{background:rgba(250,247,239,.1); opacity:1;}
.dash-main{padding:28px 30px; background:var(--paper-dim);}
.dash-topline{display:flex; justify-content:space-between; align-items:center; margin-bottom:22px; flex-wrap:wrap; gap:12px;}
.stat-row{display:grid; grid-template-columns:repeat(4,1fr); gap:16px; margin-bottom:26px;}
.stat-box{background:#fff; border:1px solid var(--line); border-radius:12px; padding:18px;}
.stat-box .num{font-family:'Space Mono',monospace; font-size:24px; font-weight:700; color:var(--ink);}
.stat-box .lbl{font-size:12px; color:var(--slate); margin-top:4px;}
.dash-panel{background:#fff; border:1px solid var(--line); border-radius:14px; padding:22px; margin-bottom:22px;}
.dash-panel h4{font-size:16px; margin-bottom:14px; display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:10px;}
table{width:100%; border-collapse:collapse; font-size:13.5px;}
th{text-align:left; font-family:'Space Mono',monospace; font-size:10.5px; text-transform:uppercase; letter-spacing:.05em; color:var(--slate); padding:8px 10px; border-bottom:1px solid var(--line);}
td{padding:10px; border-bottom:1px solid var(--line);}
.pill{font-size:11px; padding:3px 9px; border-radius:20px; font-weight:600;}
.pill.live{background:rgba(63,144,102,.14); color:var(--sage);}
.pill.warn{background:rgba(225,85,63,.12); color:var(--coral);}
.edit-btn{font-size:12px; background:var(--paper-dim); border:1px solid var(--line); padding:5px 10px; border-radius:6px;}
.plan-edit-grid{display:grid; grid-template-columns:repeat(4,1fr); gap:14px;}
.plan-edit-grid .pec{border:1px solid var(--line); border-radius:10px; padding:14px; background:var(--paper-dim);}
.plan-edit-grid label{font-size:10.5px; font-family:'Space Mono',monospace; text-transform:uppercase; color:var(--slate); display:block; margin:8px 0 3px;}
.plan-edit-grid input{padding:7px 9px; font-size:13px;}
.save-row{display:flex; justify-content:flex-end; margin-top:14px;}
@media(max-width:900px){
  .dash-shell{grid-template-columns:1fr;}
  .dash-side{display:flex; overflow-x:auto; gap:4px;}
  .dash-side nav{display:flex; gap:4px;}
  .d-user{display:none;}
  .stat-row{grid-template-columns:1fr 1fr;}
  .plan-edit-grid{grid-template-columns:1fr 1fr;}
}

/* theme customizer */
.swatch-row{display:flex; gap:14px; flex-wrap:wrap;}
.swatch-item{text-align:center;}
.swatch-item input[type=color]{width:52px; height:40px; border:1px solid var(--line); border-radius:8px; padding:2px; background:#fff;}
.swatch-item span{display:block; font-size:10.5px; font-family:'Space Mono',monospace; color:var(--slate); margin-top:5px;}
.font-preview{padding:16px; border:1px solid var(--line); border-radius:10px; background:var(--paper-dim); font-family:var(--logo-font); font-size:22px; margin-top:8px;}

/* login page */
.login-shell{max-width:420px; margin:60px auto; background:#fff; border:1px solid var(--line); border-radius:20px; padding:34px; box-shadow:0 20px 50px rgba(27,42,74,.1);}
.tab-row{display:flex; gap:6px; background:var(--paper-dim); padding:5px; border-radius:30px; margin-bottom:22px;}
.tab-row button{flex:1; padding:9px; border:none; border-radius:26px; background:transparent; font-size:13px; font-weight:600; color:var(--slate);}
.tab-row button.active{background:var(--ink); color:#fff;}
.hint-box{background:var(--paper-dim); border:1px dashed var(--line); border-radius:10px; padding:10px 12px; font-size:12px; margin-top:12px; color:var(--slate);}

/* checkout */
.checkout-grid{display:grid; grid-template-columns:1.2fr .8fr; gap:24px;}
.gateway-opt{display:flex; align-items:center; gap:12px; border:1px solid var(--line); border-radius:12px; padding:14px 16px; margin-bottom:10px; cursor:pointer;}
.gateway-opt.selected{border-color:var(--coral); background:rgba(225,85,63,.05);}
.gateway-opt img,.gateway-opt .gicon{width:34px;height:34px;border-radius:8px; background:var(--ink); color:var(--chalk); display:flex; align-items:center; justify-content:center; font-family:'Space Mono',monospace; font-weight:700; font-size:11px;}
.summary-box{background:#fff; border:1px solid var(--line); border-radius:14px; padding:20px;}
.summary-row{display:flex; justify-content:space-between; font-size:13.5px; padding:8px 0; border-top:1px dashed var(--line);}
.summary-row:first-child{border-top:none;}
@media(max-width:820px){.checkout-grid{grid-template-columns:1fr;}}

/* lead cards (Find Tuition) */
.lead-card{background:#fff; border:1px solid var(--line); border-radius:14px; padding:16px 18px 16px 20px; position:relative; overflow:hidden;}
.lead-card::before{content:""; position:absolute; left:0; top:0; bottom:0; width:4px; background:var(--coral);}
.lead-top{display:flex; justify-content:space-between; align-items:center; margin-bottom:8px; gap:10px;}
.lead-id{font-family:'Space Mono',monospace; font-size:11px; font-weight:700; color:var(--coral); background:rgba(225,85,63,.08); padding:2px 8px; border-radius:6px;}
.lead-date{font-size:10.5px; color:var(--slate); font-family:'Space Mono',monospace; white-space:nowrap;}
.lead-title{font-family:'Fraunces',serif; font-size:17px; font-weight:600; margin-bottom:6px; line-height:1.3;}
.lead-title .by{font-family:'Work Sans',sans-serif; font-weight:400; font-size:13px; color:var(--slate);}
.lead-meta{display:flex; flex-wrap:wrap; gap:6px 14px; font-size:12.5px; color:var(--slate); margin-bottom:10px;}
.lead-meta span{display:inline-flex; align-items:center; gap:4px;}
.lead-badges{display:flex; gap:6px; flex-wrap:wrap; margin-bottom:10px;}
.lead-details{font-size:12.5px; color:var(--slate); font-style:italic; margin-bottom:10px; padding-left:2px; border-left:2px solid var(--line); padding-left:10px;}
.lead-contact{background:var(--paper-dim); border-radius:10px; padding:10px 14px; display:flex; align-items:center; justify-content:space-between; gap:12px; flex-wrap:wrap;}
.lead-contact .val{font-size:13px;}

/* mini star rating display */
.star-rating{color:var(--chalk); font-size:14px; letter-spacing:1px;}
.star-input{display:flex; gap:4px; font-size:24px; cursor:pointer;}
.star-input span{color:var(--line); transition:.1s;}
.star-input span.on{color:var(--chalk);}

/* testimonial cards */
.testi-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:20px;}
.testi-card{background:#fff; border:1px solid var(--line); border-radius:16px; padding:22px;}
.testi-card .stars{margin-bottom:10px;}
.testi-card p.quote{font-size:14px; color:var(--ink-soft); line-height:1.6; margin-bottom:14px;}
.testi-card .who{display:flex; align-items:center; gap:10px;}
.testi-card .who .nm{font-weight:600; font-size:13.5px;}
.testi-card .who .role{font-size:11px; color:var(--slate); text-transform:uppercase; letter-spacing:.04em;}
@media(max-width:980px){.testi-grid{grid-template-columns:1fr 1fr;}}
@media(max-width:640px){.testi-grid{grid-template-columns:1fr;}}

/* review list on tutor profile */
.review-item{border-top:1px solid var(--line); padding:14px 0;}
.review-item:first-child{border-top:none;}
.review-item .rh{display:flex; justify-content:space-between; align-items:center; margin-bottom:4px;}
.review-item .rname{font-weight:600; font-size:13.5px;}
.review-item .rdate{font-size:11px; color:var(--slate); font-family:'Space Mono',monospace;}

.toast{position:fixed; bottom:24px; left:50%; transform:translateX(-50%) translateY(20px); background:var(--ink); color:var(--paper); padding:13px 22px; border-radius:30px; font-size:13.5px; opacity:0; pointer-events:none; transition:.25s; z-index:200; box-shadow:0 10px 24px rgba(0,0,0,.25); max-width:90vw; text-align:center;}
.toast.show{opacity:1; transform:translateX(-50%) translateY(0);}
