:root{
  --bg:#0a0f1e;--panel:#0d1426;--panel2:#111a30;
  --accent:#3b82f6;--accent2:#6366f1;--highlight:#63b3ed;
  --t1:#f1f5f9;--t2:#94a3b8;--t3:#64748b;
  --border:rgba(255,255,255,.08);--border-h:rgba(255,255,255,.15);
  --green:#34d399;--green-bg:rgba(52,211,153,.12);
  --sans:-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --slide:320ms cubic-bezier(.4,0,.2,1);
}
*{box-sizing:border-box;margin:0;padding:0}
body{background:#060a14;font-family:var(--sans);display:flex;justify-content:center;align-items:center;min-height:100vh;color:var(--t1);-webkit-font-smoothing:antialiased}
.phone{width:390px;height:820px;border-radius:40px;background:var(--bg);position:relative;overflow:hidden;border:1px solid rgba(255,255,255,.1);box-shadow:0 40px 100px rgba(0,0,0,.5),0 0 0 1px rgba(255,255,255,.04)}
.status-bar{display:none}
/* Close button — returns to /internships */
.close-x{position:absolute;top:14px;right:16px;width:34px;height:34px;border-radius:50%;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:60;transition:all .2s;text-decoration:none;color:var(--t2);font-size:18px;line-height:1}
.close-x:hover{background:rgba(255,255,255,.12);color:var(--t1)}
.close-x:active{transform:scale(.9)}
.screen-container{position:absolute;top:0;bottom:0;left:0;right:0;overflow:hidden}
.screen{position:absolute;inset:0;overflow-y:auto;padding:24px 20px 32px;transform:translateX(100%);opacity:0;transition:transform var(--slide),opacity var(--slide);pointer-events:none;scrollbar-width:none}
.screen::-webkit-scrollbar{display:none}
.screen.active{transform:translateX(0);opacity:1;pointer-events:auto}
.screen.exit-left{transform:translateX(-30%);opacity:0}
.prog-bar{height:3px;background:rgba(255,255,255,.06);border-radius:2px;margin-bottom:20px;overflow:hidden}
.prog-fill{height:100%;background:linear-gradient(90deg,var(--accent),var(--accent2));border-radius:2px;transition:width .4s ease}
.step-label{font-size:10px;text-transform:uppercase;letter-spacing:.14em;color:var(--accent);font-weight:600;margin-bottom:10px}
.q-title{font-size:20px;font-weight:700;color:var(--t1);line-height:1.3;margin-bottom:6px}
.q-hint{font-size:13px;color:var(--t3);margin-bottom:20px;line-height:1.5}
.badge{display:inline-block;font-size:9px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);background:rgba(59,130,246,.1);border:1px solid rgba(59,130,246,.25);padding:4px 10px;border-radius:6px;margin-bottom:14px}
.intro-title{font-size:24px;font-weight:700;color:var(--t1);line-height:1.25;margin-bottom:10px}
.intro-title span{color:var(--highlight)}
.intro-sub{font-size:13px;color:var(--t3);line-height:1.65;margin-bottom:24px}
.strength-box{background:var(--panel);border:1px solid var(--border);border-radius:14px;padding:18px;margin-bottom:24px}
.strength-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}
.strength-label{font-size:12px;color:var(--t3);font-weight:500}
.strength-pct{font-size:20px;font-weight:700;color:var(--t2)}
.strength-sections{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.strength-sec{font-size:11px;color:var(--t3);padding:8px 10px;background:var(--panel2);border-radius:8px;border:1px solid var(--border);display:flex;align-items:center;gap:6px}
.strength-dot{width:6px;height:6px;border-radius:50%;background:var(--border-h);flex-shrink:0}
.steps-preview{margin-bottom:24px}
.steps-preview-title{font-size:11px;color:var(--t3);text-transform:uppercase;letter-spacing:.08em;font-weight:600;margin-bottom:12px}
.step-item{display:flex;align-items:center;gap:10px;padding:8px 0;font-size:13px;color:var(--t2)}
.step-dot{width:7px;height:7px;border-radius:50%;border:1.5px solid var(--accent);flex-shrink:0}
.btn-primary{display:block;width:100%;padding:15px;background:linear-gradient(135deg,var(--accent),var(--accent2));color:#fff;border:none;border-radius:14px;font-family:var(--sans);font-size:15px;font-weight:700;cursor:pointer;transition:all .2s;text-align:center}
.btn-primary:hover{opacity:.9;transform:translateY(-1px)}
.btn-disabled{opacity:.35;pointer-events:none}
.btn-skip{display:block;width:100%;text-align:center;padding:10px;background:none;border:none;color:var(--t3);font-size:12px;cursor:pointer;font-family:var(--sans);margin-top:8px;transition:color .2s}
.btn-skip:hover{color:var(--t2)}
.btn-row{margin-top:24px;flex-shrink:0}
.btn-secondary{display:block;width:100%;padding:13px;background:transparent;color:var(--t2);border:1.5px solid var(--border);border-radius:14px;font-family:var(--sans);font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;text-align:center;margin-top:10px}
.btn-secondary:hover{border-color:var(--border-h);color:var(--t1)}
.opt{background:var(--panel);border:1.5px solid var(--border);border-radius:12px;padding:14px 16px;cursor:pointer;transition:all .2s;margin-bottom:10px;font-size:14px;color:var(--t2);font-family:var(--sans)}
.opt:hover{border-color:var(--accent);background:var(--panel2)}
.opt.selected{border-color:var(--accent);color:var(--t1);background:rgba(59,130,246,.08);box-shadow:0 0 0 3px rgba(59,130,246,.08)}
.search-input{width:100%;padding:12px 14px;border-radius:10px;border:1.5px solid var(--border);background:var(--panel);color:var(--t1);font-family:var(--sans);font-size:14px;outline:none;transition:border-color .2s;margin-bottom:12px}
.search-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(59,130,246,.1)}
.search-input::placeholder{color:var(--t3)}
.uni-list{max-height:320px;overflow-y:auto;scrollbar-width:thin;scrollbar-color:var(--border) transparent;border-radius:10px}
.uni-item{padding:12px 14px;border-bottom:1px solid var(--border);font-size:13px;color:var(--t2);cursor:pointer;transition:all .15s}
.uni-item:hover{background:var(--panel2);color:var(--t1)}
.uni-item.selected{background:rgba(59,130,246,.08);color:var(--accent);border-left:3px solid var(--accent)}
.uni-item:last-child{border-bottom:none}
.uni-cat{font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--t3);font-weight:600;padding:10px 14px 4px;background:var(--panel2);border-bottom:1px solid var(--border)}
/* Form inputs */
.form-group{margin-bottom:14px}
.form-label{font-size:11px;color:var(--t3);font-weight:600;text-transform:uppercase;letter-spacing:.06em;margin-bottom:6px;display:block}
.form-input{width:100%;padding:12px 14px;border-radius:10px;border:1.5px solid var(--border);background:var(--panel);color:var(--t1);font-family:var(--sans);font-size:14px;outline:none;transition:border-color .2s}
.form-input:focus{border-color:var(--accent)}
.form-input::placeholder{color:var(--t3)}
/* Course filter */
.course-cat{font-size:11px;font-weight:600;color:var(--accent);padding:12px 0 6px;border-bottom:1px solid var(--border);margin-bottom:8px;text-transform:uppercase;letter-spacing:.06em}
.course-opt{padding:10px 14px;border-radius:10px;border:1.5px solid var(--border);background:var(--panel);margin-bottom:6px;font-size:13px;color:var(--t2);cursor:pointer;transition:all .2s;font-family:var(--sans)}
.course-opt:hover{border-color:var(--accent);color:var(--t1)}
.course-opt.selected{border-color:var(--accent);color:var(--accent);background:rgba(59,130,246,.08)}
.course-opt .course-sub{font-size:11px;color:var(--t3);margin-top:2px;display:block}
/* Chip grids */
.cat-label{font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--t3);font-weight:600;margin:16px 0 8px}
.cat-label:first-child{margin-top:0}
.chip-grid{display:flex;flex-wrap:wrap;gap:8px}
.chip{padding:8px 14px;border-radius:20px;border:1.5px solid var(--border);background:transparent;color:var(--t2);font-size:12px;font-weight:500;cursor:pointer;transition:all .2s;user-select:none;font-family:var(--sans)}
.chip:hover{border-color:var(--accent);color:var(--accent)}
.chip.selected{border-color:var(--accent);color:var(--accent);background:rgba(59,130,246,.08)}
/* Project cards with description */
.proj-card{background:var(--panel);border:1.5px solid var(--border);border-radius:12px;padding:14px;margin-bottom:10px;transition:all .2s}
.proj-card.selected{border-color:var(--accent);background:rgba(59,130,246,.06)}
.proj-card-head{display:flex;align-items:center;justify-content:space-between;cursor:pointer}
.proj-card-name{font-size:14px;font-weight:600;color:var(--t2);transition:color .2s}
.proj-card.selected .proj-card-name{color:var(--t1)}
.proj-card-check{width:20px;height:20px;border-radius:6px;border:1.5px solid var(--border);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .2s;font-size:12px;color:transparent}
.proj-card.selected .proj-card-check{border-color:var(--accent);background:var(--accent);color:#fff}
.proj-card-sub{font-size:11px;color:var(--t3);margin-top:4px}
.proj-desc-wrap{max-height:0;overflow:hidden;transition:max-height .3s ease,margin .3s ease;margin-top:0}
.proj-card.selected .proj-desc-wrap{max-height:120px;margin-top:10px}
.proj-desc{width:100%;padding:10px 12px;border-radius:8px;border:1.5px solid var(--border);background:var(--panel2);color:var(--t1);font-family:var(--sans);font-size:12px;outline:none;resize:none;height:60px;line-height:1.5;transition:border-color .2s}
.proj-desc:focus{border-color:var(--accent)}
.proj-desc::placeholder{color:var(--t3)}
.use-example{font-size:10px;color:var(--accent);background:none;border:none;cursor:pointer;font-family:var(--sans);padding:4px 0;margin-top:4px;opacity:.7;transition:opacity .15s;display:block}
.use-example:hover{opacity:1}
/* Voice / Mic */
.mic-row{display:flex;align-items:center;gap:8px;margin-top:8px}
.mic-btn{width:36px;height:36px;border-radius:50%;border:1.5px solid var(--border);background:var(--panel);color:var(--t3);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;flex-shrink:0}
.mic-btn:hover{border-color:var(--accent);color:var(--accent)}
.mic-btn.recording{background:rgba(248,113,113,.15);border-color:#f87171;color:#f87171;animation:micPulse 1.2s infinite}
@keyframes micPulse{0%,100%{box-shadow:0 0 0 0 rgba(248,113,113,.3)}50%{box-shadow:0 0 0 8px rgba(248,113,113,0)}}
.mic-status{font-size:11px;color:var(--t3);flex:1}
.mic-lang{display:flex;align-items:center;background:rgba(255,255,255,.06);border:1px solid var(--border);border-radius:14px;padding:2px;gap:1px;flex-shrink:0}
.mic-lang-opt{font-size:9px;font-weight:600;padding:3px 8px;border-radius:12px;cursor:pointer;color:var(--t3);background:none;border:none;transition:all .15s;font-family:var(--sans);letter-spacing:.03em}
.mic-lang-opt.active{background:rgba(59,130,246,.15);color:var(--accent)}
/* Gap speak test */
.gap-speak{background:var(--panel);border:1.5px solid rgba(59,130,246,.2);border-radius:14px;padding:18px;margin:16px 0}
.gap-speak-title{font-size:12px;color:var(--accent);text-transform:uppercase;letter-spacing:.08em;font-weight:600;margin-bottom:6px}
.gap-speak-sub{font-size:12px;color:var(--t3);line-height:1.5;margin-bottom:14px}
.gap-speak-prompt{font-size:14px;font-weight:600;color:var(--t1);line-height:1.4;margin-bottom:14px;padding:12px;background:var(--panel2);border-radius:10px;border:1px solid var(--border)}
.gap-speak-result{min-height:60px;padding:12px;border-radius:10px;border:1.5px solid var(--border);background:var(--panel2);color:var(--t1);font-size:13px;line-height:1.5;margin-bottom:10px;white-space:pre-wrap}
.gap-speak-result.empty{color:var(--t3);font-style:italic}
.gap-speak-feedback{font-size:12px;color:var(--t2);line-height:1.5;padding:10px 12px;background:rgba(52,211,153,.06);border:1px solid rgba(52,211,153,.15);border-radius:8px;margin-top:10px;display:none}
.gap-speak-feedback.show{display:block}
/* Next step card */
.gap-next{border-radius:14px;padding:20px;margin-top:20px;text-align:center}
.gap-next-fix{background:rgba(248,113,113,.06);border:1.5px solid rgba(248,113,113,.2)}
.gap-next-ready{background:rgba(52,211,153,.06);border:1.5px solid rgba(52,211,153,.2)}
.gap-next-title{font-size:16px;font-weight:700;color:var(--t1);margin-bottom:6px}
.gap-next-sub{font-size:13px;color:var(--t3);line-height:1.5;margin-bottom:16px}
.gap-next-btn{display:block;width:100%;padding:14px;border-radius:12px;border:none;font-family:var(--sans);font-size:15px;font-weight:700;cursor:pointer;transition:all .2s;margin-bottom:8px}
.gap-next-btn:hover{opacity:.9;transform:translateY(-1px)}
.gap-next-btn-primary{background:linear-gradient(135deg,var(--accent),var(--accent2));color:#fff}
.gap-next-btn-fix{background:rgba(248,113,113,.15);color:#f87171;border:1.5px solid rgba(248,113,113,.3)}
.gap-next-btn-fix:hover{background:rgba(248,113,113,.25)}
.gap-next-btn-interview{background:rgba(52,211,153,.12);color:var(--green);border:1.5px solid rgba(52,211,153,.25)}
.gap-next-btn-interview:hover{background:rgba(52,211,153,.2)}
.gap-next-step{font-size:11px;color:var(--t3);margin-top:12px;display:flex;align-items:center;justify-content:center;gap:8px}
.gap-next-dot{width:8px;height:8px;border-radius:50%}
.gap-next-dot.done{background:var(--green)}
.gap-next-dot.current{background:var(--accent)}
.gap-next-dot.upcoming{background:rgba(255,255,255,.12)}
/* Hub */
.hub-card{display:flex;align-items:center;gap:14px;padding:16px;border-radius:14px;border:1.5px solid var(--border);background:var(--panel);margin-bottom:10px;cursor:pointer;transition:all .25s}
.hub-card:hover{border-color:var(--accent);background:var(--panel2);transform:translateY(-1px)}
.hub-card:active{transform:scale(.98)}
.hub-card-icon{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:700;flex-shrink:0}
.hub-card-body{flex:1;min-width:0}
.hub-card-title{font-size:15px;font-weight:700;color:var(--t1);margin-bottom:3px}
.hub-card-sub{font-size:12px;color:var(--t3);line-height:1.45}
.hub-card-arrow{font-size:22px;color:var(--t3);flex-shrink:0;transition:transform .2s}
.hub-card:hover .hub-card-arrow{transform:translateX(3px);color:var(--accent)}
/* Hub card states */
.hub-card.needs-cv{opacity:.5;pointer-events:none}
.hub-card.needs-cv .hub-card-sub::after{content:' (build your CV first)';color:var(--accent);font-weight:600}
.hub-card-done{position:absolute;top:8px;right:8px;font-size:9px;font-weight:700;padding:2px 7px;border-radius:4px;background:var(--green-bg);color:var(--green);text-transform:uppercase;letter-spacing:.05em}
.hub-card{position:relative}
.hub-welcome{text-align:center;margin-bottom:8px;font-size:13px;color:var(--accent);font-weight:500}
/* Match screen */
.match-card{background:var(--panel);border:1px solid var(--border);border-radius:14px;padding:16px;margin-bottom:10px;transition:all .2s;cursor:pointer}
.match-card:hover{border-color:var(--accent);background:var(--panel2)}
.match-card-head{display:flex;align-items:center;gap:12px;margin-bottom:10px}
.match-card-logo{width:40px;height:40px;border-radius:10px;background:var(--panel2);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:700;color:var(--t3);flex-shrink:0;overflow:hidden}
.match-card-logo img{width:100%;height:100%;object-fit:contain;padding:4px}
.match-card-info{flex:1;min-width:0}
.match-card-co{font-size:15px;font-weight:700;color:var(--t1)}
.match-card-prog{font-size:12px;color:var(--t3);margin-top:2px}
.match-card-meta{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:8px}
.match-pill{font-size:10px;font-weight:600;padding:3px 8px;border-radius:6px}
.match-pill-paid{background:rgba(52,211,153,.1);color:var(--green)}
.match-pill-ind{background:rgba(59,130,246,.1);color:var(--accent)}
.match-pill-lvl{background:rgba(251,191,36,.1);color:#fbbf24}
.match-pill-rolling{background:rgba(52,211,153,.08);color:var(--green);border:1px solid rgba(52,211,153,.2)}
.match-score{font-size:11px;color:var(--t3);margin-top:6px;display:flex;align-items:center;gap:6px}
.match-score-bar{flex:1;height:4px;background:rgba(255,255,255,.06);border-radius:2px;overflow:hidden}
.match-score-fill{height:100%;border-radius:2px;background:var(--green)}
.match-score-pct{font-size:11px;font-weight:600;color:var(--green)}
.match-empty{text-align:center;padding:40px 16px;color:var(--t3);font-size:13px;line-height:1.6}
.match-filter-row{display:flex;gap:6px;margin-bottom:14px;flex-wrap:wrap}
.custom-row{display:flex;gap:8px;margin-top:14px}
.custom-input{flex:1;padding:10px 12px;border-radius:10px;border:1.5px solid var(--border);background:var(--panel);color:var(--t1);font-family:var(--sans);font-size:13px;outline:none;transition:border-color .2s}
.custom-input:focus{border-color:var(--accent)}
.custom-input::placeholder{color:var(--t3)}
.add-btn{padding:10px 16px;border-radius:10px;border:none;background:var(--accent);color:#fff;font-family:var(--sans);font-size:13px;font-weight:600;cursor:pointer;transition:opacity .2s;flex-shrink:0}
.add-btn:hover{opacity:.85}
.text-area{width:100%;padding:12px 14px;border-radius:10px;border:1.5px solid var(--border);background:var(--panel);color:var(--t1);font-family:var(--sans);font-size:13px;outline:none;resize:none;height:80px;transition:border-color .2s;margin-top:14px;line-height:1.5}
.text-area:focus{border-color:var(--accent)}
.text-area::placeholder{color:var(--t3)}
.toast{position:absolute;bottom:20px;left:20px;right:20px;background:rgba(52,211,153,.12);border:1px solid rgba(52,211,153,.25);color:var(--green);border-radius:12px;padding:10px 14px;font-size:13px;font-weight:600;text-align:center;transform:translateY(80px);opacity:0;transition:all 300ms;z-index:20;pointer-events:none}
.toast.show{transform:translateY(0);opacity:1}
/* Completion */
.complete-circle{display:flex;justify-content:center;margin-bottom:20px;position:relative}
.complete-score{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center}
.complete-num{font-size:42px;font-weight:700;color:var(--accent);line-height:1}
.complete-lbl{font-size:11px;color:var(--t3);text-transform:uppercase;letter-spacing:.08em;margin-top:4px}
.complete-title{font-size:20px;font-weight:700;color:var(--t1);text-align:center;margin-bottom:6px}
.complete-sub{font-size:13px;color:var(--t3);text-align:center;line-height:1.6;margin-bottom:20px}
.complete-chips{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-bottom:24px}
.complete-chip{font-size:11px;font-weight:600;padding:6px 12px;border-radius:20px;background:var(--green-bg);color:var(--green);border:1px solid rgba(52,211,153,.25)}
.confetti-container{position:absolute;top:0;left:0;right:0;height:100%;pointer-events:none;overflow:hidden;z-index:5}
.confetti-piece{position:absolute;width:8px;height:8px;border-radius:2px;opacity:0}
.confetti-container.active .confetti-piece{animation:confettiFall 2.5s ease-out forwards}
@keyframes confettiFall{0%{opacity:1;transform:translateY(-20px) rotate(0deg)}15%{opacity:1}100%{opacity:0;transform:translateY(700px) rotate(720deg)}}
/* CV Preview */
.cv-preview{background:#fff;color:#1a1a1a;border-radius:12px;padding:24px 20px;margin-bottom:16px;font-size:12px;line-height:1.6;max-height:400px;overflow-y:auto}
.cv-preview h2{font-size:18px;font-weight:700;color:#0a0f1e;margin-bottom:2px}
.cv-preview .cv-contact{font-size:11px;color:#666;margin-bottom:16px}
.cv-preview .cv-section{margin-bottom:14px}
.cv-preview .cv-section-title{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:#3b82f6;border-bottom:1.5px solid #e2e8f0;padding-bottom:4px;margin-bottom:8px}
.cv-preview .cv-item{margin-bottom:6px;color:#333}
.cv-preview .cv-item strong{color:#1a1a1a}
.cv-preview .cv-chips{display:flex;flex-wrap:wrap;gap:4px}
.cv-preview .cv-chip{font-size:10px;padding:2px 8px;border-radius:10px;background:#f0f4ff;color:#3b82f6;border:1px solid #dde4f5}
/* Gap Analysis */
.gap-card{background:var(--panel);border:1px solid var(--border);border-radius:14px;padding:16px;margin-bottom:12px}
.gap-card-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}
.gap-section-name{font-size:14px;font-weight:600;color:var(--t1)}
.gap-section-score{font-size:14px;font-weight:700;color:var(--t2)}
.gap-bar{height:6px;background:rgba(255,255,255,.06);border-radius:3px;overflow:hidden}
.gap-bar-fill{height:100%;border-radius:3px;transition:width .6s ease}
.gap-green .gap-bar-fill{background:var(--green)}
.gap-green .gap-section-score{color:var(--green)}
.gap-amber .gap-bar-fill{background:#fbbf24}
.gap-amber .gap-section-score{color:#fbbf24}
.gap-red .gap-bar-fill{background:#f87171}
.gap-red .gap-section-score{color:#f87171}
.gap-advice{font-size:12px;color:var(--t3);margin-top:8px;line-height:1.5}
.gap-complete{font-size:12px;color:var(--green);margin-top:8px;font-weight:600}
.gap-format{background:var(--panel2);border:1px solid var(--border);border-radius:14px;padding:16px;margin-bottom:16px}
.gap-format-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}
.gap-format-title{font-size:12px;color:var(--accent);text-transform:uppercase;letter-spacing:.08em;font-weight:600}
.gap-format-score{font-size:14px;font-weight:700;color:var(--accent)}
.gap-format-item{display:flex;align-items:center;gap:8px;padding:6px 0;font-size:12px;color:var(--t2)}
.gap-format-check{width:18px;height:18px;border-radius:5px;display:flex;align-items:center;justify-content:center;font-size:11px;flex-shrink:0}
.gap-format-check.pass{background:var(--green-bg);color:var(--green);border:1px solid rgba(52,211,153,.3)}
.gap-format-check.fail{background:rgba(248,113,113,.1);color:#f87171;border:1px solid rgba(248,113,113,.3)}
.gap-priority{background:var(--panel2);border:1px solid var(--border);border-radius:14px;padding:18px;margin:20px 0}
.gap-priority-title{font-size:12px;color:var(--accent);text-transform:uppercase;letter-spacing:.08em;font-weight:600;margin-bottom:14px}
.gap-priority-item{padding:10px 0;border-bottom:1px solid var(--border);font-size:13px;color:var(--t2);line-height:1.5}
.gap-priority-item:last-child{border-bottom:none}
.gap-priority-num{font-size:16px;font-weight:700;color:var(--accent);margin-right:8px}
.gap-priority-pts{font-size:11px;color:var(--accent);font-weight:600}
.gap-priority-context{font-size:11px;color:var(--t3);margin-top:4px;display:block}
.gap-bullet{background:var(--panel);border:1px solid rgba(251,191,36,.15);border-radius:14px;padding:16px;margin:16px 0}
.gap-bullet-title{font-size:12px;color:#fbbf24;text-transform:uppercase;letter-spacing:.08em;font-weight:600;margin-bottom:10px}
.gap-bullet-item{font-size:12px;color:var(--t2);line-height:1.5;padding:6px 0;border-bottom:1px solid var(--border)}
.gap-bullet-item:last-child{border-bottom:none}
.gap-bullet-item .bullet-pass{color:var(--green)}
.gap-bullet-item .bullet-fail{color:#f87171}
.gap-context{background:var(--panel);border:1px solid rgba(59,130,246,.15);border-radius:14px;padding:18px;margin:16px 0}
.gap-context-title{font-size:12px;color:var(--accent);text-transform:uppercase;letter-spacing:.08em;font-weight:600;margin-bottom:10px}
.gap-context-text{font-size:13px;color:var(--t2);line-height:1.6}
.gap-interview{background:var(--panel2);border:1px solid rgba(99,179,237,.15);border-radius:14px;padding:18px;margin:16px 0}
.gap-interview-title{font-size:12px;color:var(--highlight);text-transform:uppercase;letter-spacing:.08em;font-weight:600;margin-bottom:10px}
.gap-interview-text{font-size:13px;color:var(--t2);line-height:1.6}
/* Interview Practice */
.itag{font-size:10px;font-weight:600;padding:3px 8px;border-radius:6px;display:inline-block}
.itag-project{background:rgba(99,102,241,.12);color:#818cf8}
.itag-skills{background:rgba(59,130,246,.12);color:#60a5fa}
.itag-activity{background:rgba(52,211,153,.12);color:#34d399}
.itag-motivation{background:rgba(251,191,36,.12);color:#fbbf24}
.itag-problem{background:rgba(244,63,94,.12);color:#f43f5e}
.itag-reflection{background:rgba(167,139,250,.12);color:#a78bfa}
.itag-goals{background:rgba(45,212,191,.12);color:#2dd4bf}
.iq-row{padding:14px;border-radius:12px;border:1px solid var(--border);background:var(--panel);margin-bottom:10px;cursor:pointer;display:flex;align-items:center;gap:12px;transition:all .2s}
.iq-row:hover{border-color:var(--accent);background:var(--panel2)}
.iq-num{width:28px;height:28px;border-radius:50%;background:rgba(255,255,255,.06);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:var(--t3);flex-shrink:0}
.iq-num.done{background:var(--green-bg);color:var(--green)}
.iq-num.next{background:rgba(59,130,246,.12);color:var(--accent)}
.iq-content{flex:1;min-width:0}
.iq-text{font-size:13px;color:var(--t2);line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.iq-why{font-size:11px;color:var(--t3);margin-top:4px}
.iq-arrow{color:var(--t3);font-size:16px;flex-shrink:0}
.iq-dots{display:flex;gap:6px;justify-content:center;margin-bottom:16px}
.iq-dot{width:10px;height:10px;border-radius:50%;background:rgba(255,255,255,.08)}
.iq-dot.done{background:var(--green)}
.iq-dot.next{background:var(--accent)}
.iq-done-count{text-align:center;font-size:12px;color:var(--t3);margin-bottom:14px}
.iq-card{background:rgba(59,130,246,.06);border:1px solid rgba(59,130,246,.15);border-radius:14px;padding:16px;margin-bottom:16px}
.iq-card-label{font-size:10px;color:var(--accent);text-transform:uppercase;letter-spacing:.08em;font-weight:600;margin-bottom:6px}
.iq-card-q{font-size:16px;font-weight:600;color:var(--t1);line-height:1.4;margin-bottom:6px}
.iq-card-why{font-size:11px;color:var(--t3)}
.star-toggle{display:flex;align-items:center;gap:8px;padding:12px;border:1.5px dashed var(--border);border-radius:10px;cursor:pointer;margin-bottom:12px;transition:border-color .2s}
.star-toggle:hover{border-color:var(--accent)}
.star-toggle-text{font-size:12px;color:var(--t3);flex:1}
.star-toggle-arrow{font-size:14px;color:var(--t3);transition:transform .2s}
.star-toggle-arrow.open{transform:rotate(180deg)}
.star-panel{display:none;padding:14px;background:var(--panel2);border-radius:10px;border:1px solid var(--border);margin-bottom:14px}
.star-panel.visible{display:block}
.star-row{display:flex;gap:10px;padding:8px 0;align-items:flex-start}
.star-letter{width:24px;height:24px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;flex-shrink:0}
.star-s{background:rgba(59,130,246,.12);color:var(--accent)}
.star-t{background:rgba(251,191,36,.12);color:#fbbf24}
.star-a{background:rgba(52,211,153,.12);color:var(--green)}
.star-r{background:rgba(167,139,250,.12);color:#a78bfa}
.star-text{font-size:12px;color:var(--t2);line-height:1.5}
.wc-row{display:flex;justify-content:flex-end;padding:4px 0;font-size:11px;color:var(--t3)}
.fb-score-wrap{display:flex;justify-content:center;margin-bottom:16px;position:relative}
.fb-score-num{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center}
.fb-score-val{font-size:36px;font-weight:700;color:var(--accent);line-height:1}
.fb-score-lbl{font-size:11px;color:var(--t3);margin-top:2px}
.fb-card{border-radius:12px;padding:14px;margin-bottom:12px}
.fb-card-good{background:rgba(52,211,153,.06);border:1px solid rgba(52,211,153,.15)}
.fb-card-improve{background:rgba(251,191,36,.06);border:1px solid rgba(251,191,36,.15)}
.fb-card-label{font-size:10px;text-transform:uppercase;letter-spacing:.08em;font-weight:600;margin-bottom:6px}
.fb-card-good .fb-card-label{color:var(--green)}
.fb-card-improve .fb-card-label{color:#fbbf24}
.fb-card-text{font-size:13px;color:var(--t2);line-height:1.6}
.fb-sample-toggle{display:flex;align-items:center;gap:8px;padding:12px;border:1.5px dashed var(--border);border-radius:10px;cursor:pointer;margin:12px 0;transition:border-color .2s}
.fb-sample-toggle:hover{border-color:var(--accent)}
.fb-sample-panel{display:none;background:var(--panel2);border:1px solid var(--border);border-radius:10px;padding:14px;margin-bottom:12px;font-size:13px;color:var(--t2);line-height:1.6}
.fb-sample-panel.visible{display:block}
.fb-sample-panel em{color:var(--accent);font-style:normal;font-weight:600}
@media(max-height:860px){.phone{transform:scale(.9);transform-origin:center center}}

/* ══════════════════════════════════════════════════════════════
   DUOLINGO + BRAINROT DESIGN SYSTEM
   Rounded, bubbly, animated, thumb-friendly, dopamine-driven
   ══════════════════════════════════════════════════════════════ */

/* ── BOTTOM NAV BAR (Duolingo-style) ── */
.bottom-nav{position:absolute;bottom:0;left:0;right:0;height:56px;background:var(--panel);border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-around;z-index:50;padding:0 8px}
.bottom-nav-item{display:flex;flex-direction:column;align-items:center;gap:2px;cursor:pointer;padding:6px 12px;border-radius:12px;transition:all .2s;-webkit-tap-highlight-color:transparent}
.bottom-nav-item:active{transform:scale(.9)}
.bottom-nav-item.active{background:rgba(59,130,246,.1)}
.bottom-nav-icon{width:24px;height:24px;display:flex;align-items:center;justify-content:center;font-size:16px;color:var(--t3);transition:color .2s}
.bottom-nav-item.active .bottom-nav-icon{color:var(--accent)}
.bottom-nav-label{font-size:9px;font-weight:600;color:var(--t3);letter-spacing:.02em;transition:color .2s}
.bottom-nav-item.active .bottom-nav-label{color:var(--accent)}
/* Adjust screen container to make room for bottom nav */
.has-bottom-nav .screen-container{bottom:56px}

/* ── ANIMATED PROGRESS RING (always visible, top of screen) ── */
.progress-ring-wrap{display:flex;align-items:center;gap:10px;margin-bottom:16px;padding:10px 14px;background:var(--panel);border:1px solid var(--border);border-radius:14px}
.progress-ring-svg{width:40px;height:40px;flex-shrink:0}
.progress-ring-circle{transition:stroke-dashoffset .6s ease;transform:rotate(-90deg);transform-origin:center}
.progress-ring-info{flex:1}
.progress-ring-level{font-size:13px;font-weight:700;color:var(--t1)}
.progress-ring-xp{font-size:11px;color:var(--t3)}
.progress-ring-streak{font-size:10px;color:#fbbf24;font-weight:600;margin-top:2px}

/* ── CARD POP ANIMATION (tap feedback) ── */
.pop-card{transition:transform .15s cubic-bezier(.2,.8,.4,1.4),box-shadow .15s;cursor:pointer;-webkit-tap-highlight-color:transparent}
.pop-card:active{transform:scale(.96)}
.pop-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.3)}

/* ── GLOW PULSE on next action ── */
.glow-pulse{animation:glowPulse 2s ease-in-out infinite}
@keyframes glowPulse{
  0%,100%{box-shadow:0 0 0 0 rgba(59,130,246,.2)}
  50%{box-shadow:0 0 0 8px rgba(59,130,246,0)}
}
.glow-green{animation:glowGreen 2s ease-in-out infinite}
@keyframes glowGreen{
  0%,100%{box-shadow:0 0 0 0 rgba(52,211,153,.2)}
  50%{box-shadow:0 0 0 8px rgba(52,211,153,0)}
}

/* ── XP POPUP (floating +XP after actions) ── */
.xp-popup{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);font-size:28px;font-weight:800;color:var(--accent);pointer-events:none;z-index:100;opacity:0;text-shadow:0 0 20px rgba(59,130,246,.5)}
.xp-popup.show{animation:xpFloat .8s ease-out forwards}
@keyframes xpFloat{
  0%{opacity:0;transform:translate(-50%,-50%) scale(.5)}
  30%{opacity:1;transform:translate(-50%,-70%) scale(1.2)}
  100%{opacity:0;transform:translate(-50%,-120%) scale(.8)}
}

/* ── ACHIEVEMENT BADGE (unlock animations) ── */
.achievement{display:flex;align-items:center;gap:12px;padding:14px 16px;border-radius:16px;background:linear-gradient(135deg,rgba(59,130,246,.1),rgba(99,102,241,.1));border:1.5px solid rgba(59,130,246,.2);margin-bottom:12px;animation:achieveIn .4s cubic-bezier(.2,.8,.4,1.4)}
@keyframes achieveIn{0%{opacity:0;transform:scale(.8) translateY(10px)}100%{opacity:1;transform:scale(1) translateY(0)}}
.achievement-icon{width:40px;height:40px;border-radius:12px;background:linear-gradient(135deg,var(--accent),var(--accent2));display:flex;align-items:center;justify-content:center;font-size:18px;color:#fff;flex-shrink:0}
.achievement-body{flex:1}
.achievement-title{font-size:13px;font-weight:700;color:var(--t1)}
.achievement-sub{font-size:11px;color:var(--t3);margin-top:2px}

/* ── SWIPE HINT (subtle bounce arrow) ── */
.swipe-hint{text-align:center;padding:8px;font-size:11px;color:var(--t3);animation:swipeBounce 2s ease-in-out infinite}
@keyframes swipeBounce{0%,100%{transform:translateY(0)}50%{transform:translateY(-4px)}}

/* ── BUBBLY COMPONENTS (Duolingo-style rounded everything) ── */
.bubble-card{border-radius:20px;border:2px solid var(--border);padding:18px;background:var(--panel);transition:all .2s}
.bubble-card:active{transform:scale(.97)}
.bubble-btn{border-radius:16px;font-weight:700;font-size:15px;padding:16px 24px;border:none;cursor:pointer;transition:all .15s;-webkit-tap-highlight-color:transparent;width:100%;display:block;text-align:center}
.bubble-btn:active{transform:scale(.95)}
.bubble-btn-primary{background:linear-gradient(135deg,var(--accent),var(--accent2));color:#fff;box-shadow:0 4px 16px rgba(59,130,246,.3)}
.bubble-btn-green{background:linear-gradient(135deg,#34d399,#059669);color:#fff;box-shadow:0 4px 16px rgba(52,211,153,.3)}

/* ── STREAK FLAME ── */
.streak-badge{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:700;color:#fbbf24;background:rgba(251,191,36,.1);border:1px solid rgba(251,191,36,.2);padding:4px 10px;border-radius:20px}

/* ── LEVEL BADGE ── */
.level-badge{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:700;padding:4px 10px;border-radius:20px}
.level-1{color:var(--t3);background:rgba(255,255,255,.06);border:1px solid var(--border)}
.level-2{color:var(--accent);background:rgba(59,130,246,.1);border:1px solid rgba(59,130,246,.2)}
.level-3{color:#a78bfa;background:rgba(167,139,250,.1);border:1px solid rgba(167,139,250,.2)}
.level-4{color:var(--green);background:rgba(52,211,153,.1);border:1px solid rgba(52,211,153,.2)}
.level-5{color:#fbbf24;background:rgba(251,191,36,.1);border:1px solid rgba(251,191,36,.2)}

/* ── MICRO-ANIMATIONS (everything feels alive) ── */
.fade-in{animation:fadeIn .3s ease both}
@keyframes fadeIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}
.slide-up{animation:slideUp .4s cubic-bezier(.2,.8,.4,1.4) both}
@keyframes slideUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
.bounce-in{animation:bounceIn .5s cubic-bezier(.2,.8,.4,1.4) both}
@keyframes bounceIn{from{opacity:0;transform:scale(.7)}to{opacity:1;transform:scale(1)}}

/* ── HAPTIC TAP EFFECT (visual feedback for every interaction) ── */
.tap-effect{position:relative;overflow:hidden}
.tap-effect::after{content:'';position:absolute;inset:0;background:rgba(255,255,255,.06);opacity:0;transition:opacity .15s;border-radius:inherit;pointer-events:none}
.tap-effect:active::after{opacity:1}

/* Apply pop to existing interactive elements */
.opt{transition:transform .15s cubic-bezier(.2,.8,.4,1.4),border-color .2s,background .2s}
.opt:active{transform:scale(.97)}
.chip{transition:transform .12s,border-color .2s,color .2s,background .2s}
.chip:active{transform:scale(.93)}
.hub-card{transition:transform .15s cubic-bezier(.2,.8,.4,1.4),border-color .25s,background .25s}
.hub-card:active{transform:scale(.97)}
.proj-card{transition:transform .15s,border-color .2s,background .2s}
.proj-card:active{transform:scale(.98)}
.btn-primary{transition:transform .12s,opacity .15s}
.btn-primary:active{transform:scale(.96)}

/* ── SCREEN TRANSITIONS (smoother, more alive) ── */
.screen{transition:transform .35s cubic-bezier(.4,0,.0,1),opacity .3s ease}
.screen.exit-left{transform:translateX(-20%);opacity:0}

/* ── MOBILE RESPONSIVE — remove phone frame on real phones ── */
@media(max-width:420px){
  .phone{width:100%!important;height:100vh!important;height:100dvh!important;border-radius:0!important;border:none!important;box-shadow:none!important}
  body{padding:0}
  .bottom-nav{border-radius:0}
}
