:root{
  --bg:#eef3ef;--surface:#ffffff;--surface-2:#f7faf8;--ink:#15231e;--muted:#6f7f77;
  --brand:#0f5a46;--brand-2:#15745a;--brand-soft:#e8f4ef;--lime:#b7ef4a;--danger:#c64242;
  --warning:#d79b22;--line:#dfe8e3;--shadow:0 14px 40px rgba(19,55,42,.08);--radius:22px;
}
*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;background:var(--bg);color:var(--ink);font-family:"Noto Sans Arabic","Tahoma","Arial",sans-serif;line-height:1.55}button,input,select,textarea{font:inherit}button{cursor:pointer}.hidden{display:none!important}
.app-shell{min-height:100vh;display:grid;grid-template-columns:280px 1fr}.sidebar{position:sticky;top:0;height:100vh;background:linear-gradient(180deg,#0b3e31,#082d25);color:#fff;padding:24px 18px;display:flex;flex-direction:column;z-index:10}.brand{display:flex;gap:12px;align-items:center;padding:4px 8px 26px}.brand-mark{width:48px;height:48px;border-radius:16px;background:linear-gradient(145deg,var(--lime),#64d687);color:#12352a;display:grid;place-items:center;font-size:26px;font-weight:900;box-shadow:0 10px 25px rgba(183,239,74,.2)}.brand strong{display:block;font-size:16px}.brand span{display:block;color:#bcd0c8;font-size:12px;margin-top:3px}.nav-list{display:grid;gap:7px}.nav-item{border:0;background:transparent;color:#cfe0d9;border-radius:14px;padding:12px 14px;text-align:right;display:flex;align-items:center;gap:10px;transition:.2s}.nav-item span{width:24px;text-align:center;font-size:18px}.nav-item:hover,.nav-item.active{background:rgba(255,255,255,.10);color:#fff}.nav-item.active{box-shadow:inset -3px 0 0 var(--lime)}.sidebar-foot{margin-top:auto;display:grid;gap:14px}.save-indicator{display:flex;align-items:center;gap:8px;color:#bcd0c8;font-size:12px;padding:0 8px}.save-indicator i{width:8px;height:8px;border-radius:50%;background:#65d88b;box-shadow:0 0 0 5px rgba(101,216,139,.12)}
.main{min-width:0;padding:0 34px 48px}.topbar{height:104px;display:flex;align-items:center;justify-content:space-between;gap:20px}.topbar h1{margin:0;font-size:30px}.eyebrow{margin:0 0 4px;color:var(--brand-2);font-weight:800;font-size:12px;letter-spacing:.04em}.top-actions,.inline-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.primary,.secondary,.ghost,.button-link{border:0;border-radius:13px;padding:11px 17px;font-weight:800;text-decoration:none;display:inline-flex;align-items:center;justify-content:center}.primary{background:var(--brand);color:#fff;box-shadow:0 8px 18px rgba(15,90,70,.18)}.primary:hover{background:var(--brand-2)}.primary.large{padding:14px 23px}.secondary{background:var(--brand-soft);color:var(--brand)}.ghost{background:transparent;color:var(--ink);border:1px solid var(--line)}.sidebar .ghost{color:#e4efea;border-color:rgba(255,255,255,.14)}.ghost.danger{color:#ffb7b7}.link-btn{border:0;background:transparent;color:var(--brand);font-weight:800}.view{display:none;animation:fade .22s ease}.view.active{display:block}@keyframes fade{from{opacity:.4;transform:translateY(4px)}to{opacity:1;transform:none}}
.card{background:var(--surface);border:1px solid rgba(220,232,225,.9);border-radius:var(--radius);box-shadow:var(--shadow);padding:22px;margin-bottom:20px}.card-head{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:18px}.card-head h3{margin:0;font-size:20px}.hero{min-height:305px;background:linear-gradient(135deg,#0e4e3d 0%,#0c624a 58%,#198260 100%);color:#fff;display:grid;grid-template-columns:1.25fr .75fr;align-items:center;overflow:hidden;position:relative}.hero:after{content:"";position:absolute;width:330px;height:330px;border-radius:50%;background:rgba(183,239,74,.08);left:-90px;top:-120px}.hero h2{font-size:36px;line-height:1.25;margin:13px 0}.hero p{color:#d4e6df;max-width:720px}.hero .pill{background:rgba(255,255,255,.11);color:#eaf8f2}.hero-actions{display:flex;gap:11px;margin-top:22px}.hero .primary{background:var(--lime);color:#16372b}.hero .secondary{background:rgba(255,255,255,.12);color:#fff}.hero-orbit{width:220px;height:220px;position:relative;margin:auto}.orbit-core{position:absolute;inset:60px;border-radius:50%;background:var(--lime);color:#12352a;display:grid;place-items:center;font-size:43px;font-weight:900;box-shadow:0 0 0 18px rgba(255,255,255,.08),0 0 0 36px rgba(255,255,255,.04)}.hero-orbit span{position:absolute;top:50%;left:50%;transform:rotate(calc(var(--i)*72deg)) translateX(93px) rotate(calc(var(--i)*-72deg));background:#fff;color:#174535;padding:6px 9px;border-radius:9px;font-size:11px;font-weight:900}
.kpi-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:15px;margin:20px 0}.kpi{background:var(--surface);border:1px solid var(--line);border-radius:18px;padding:18px;box-shadow:0 8px 24px rgba(22,63,48,.05)}.kpi .kpi-top{display:flex;justify-content:space-between;gap:10px;align-items:center;color:var(--muted);font-size:12px}.kpi .icon{width:34px;height:34px;border-radius:11px;background:var(--brand-soft);color:var(--brand);display:grid;place-items:center;font-size:17px}.kpi strong{font-size:27px;display:block;margin:7px 0 2px}.kpi small{color:var(--muted)}.grid{display:grid;gap:20px}.grid.two{grid-template-columns:repeat(2,minmax(0,1fr))}.score{font-size:26px;font-weight:900;color:var(--brand)}
.step-list{display:grid;gap:11px}.step{display:grid;grid-template-columns:35px 1fr auto;align-items:center;gap:11px;padding:11px;background:var(--surface-2);border-radius:14px}.step b{width:35px;height:35px;border-radius:11px;background:#e5ece8;color:#64746c;display:grid;place-items:center}.step.done b{background:#dff4e6;color:#1c7d4d}.step strong{display:block}.step small{color:var(--muted)}.step .status{font-size:11px;font-weight:800;padding:5px 8px;border-radius:999px;background:#e9efec;color:#63736b}.step.done .status{background:#def4e6;color:#19784a}.empty-state{text-align:center;padding:42px;color:var(--muted);border:1px dashed #cddbd3;border-radius:16px;background:#fbfdfc}.empty-state.compact{padding:24px}.empty-state.large{padding:80px 20px}.empty-state.large span{font-size:40px;color:var(--brand)}.flow{display:flex;align-items:center;justify-content:space-between;gap:12px}.flow>div{flex:1;background:var(--surface-2);border-radius:16px;padding:16px;min-height:106px}.flow b{width:28px;height:28px;background:var(--brand);color:#fff;border-radius:9px;display:grid;place-items:center;margin-bottom:9px}.flow strong,.flow span{display:block}.flow span{font-size:12px;color:var(--muted);margin-top:4px}.flow i{color:#94a59d;font-size:24px}
.upload-grid{align-items:stretch}.upload-card{display:flex;flex-direction:column}.file-badge,.pill{display:inline-flex;padding:6px 10px;border-radius:999px;background:var(--brand-soft);color:var(--brand);font-size:11px;font-weight:900}.pill.success{background:#e0f5e8;color:#167448}.drop-zone{flex:1;min-height:170px;border:2px dashed #c7d8cf;border-radius:18px;background:var(--surface-2);display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:22px;transition:.2s}.drop-zone:hover{border-color:var(--brand);background:#f2faf6}.drop-icon{font-size:31px;color:var(--brand);margin-bottom:7px}.drop-zone small{color:var(--muted);max-width:380px;margin-top:6px}.upload-card .inline-actions{margin-top:13px}.paste-box{margin-top:14px;display:grid;gap:10px}.paste-box textarea,textarea,input,select{width:100%;border:1px solid var(--line);background:#fff;border-radius:11px;padding:10px 12px;color:var(--ink);outline:none}.paste-box textarea:focus,textarea:focus,input:focus,select:focus{border-color:#69a991;box-shadow:0 0 0 3px rgba(21,116,90,.08)}.progress{height:5px;background:#e3ebe7;border-radius:99px;margin-top:14px;overflow:hidden}.progress span{display:block;height:100%;width:60%;background:var(--brand);animation:load 1.1s infinite}@keyframes load{from{transform:translateX(190%)}to{transform:translateX(-190%)}}
.profile-summary{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.profile-item{padding:14px;background:var(--surface-2);border-radius:14px}.profile-item span{display:block;font-size:11px;color:var(--muted)}.profile-item strong{display:block;margin-top:3px}.profile-item.wide{grid-column:span 2}.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:13px}.form-grid.four{grid-template-columns:repeat(4,minmax(0,1fr))}.form-grid label{font-size:12px;font-weight:800;color:#405048;display:grid;gap:6px}.span-2{grid-column:span 2}.checkbox-label{display:flex!important;flex-direction:row!important;align-items:center;gap:8px!important;padding:10px 0}.checkbox-label input{width:auto}.filters{display:flex;gap:8px;align-items:center}.filters input{min-width:210px}.table-wrap{overflow:auto;border:1px solid var(--line);border-radius:15px}table{border-collapse:collapse;width:100%;min-width:760px;background:#fff}th,td{padding:12px 14px;text-align:right;border-bottom:1px solid #edf2ef;font-size:13px}th{background:#f5f9f7;color:#56665e;font-size:11px;position:sticky;top:0;z-index:1}tr:last-child td{border-bottom:0}.code{font-family:ui-monospace,SFMono-Regular,Consolas,monospace;font-weight:900;color:#183f32}.status-chip{display:inline-flex;padding:5px 9px;border-radius:999px;font-size:11px;font-weight:900;white-space:nowrap}.status-chip.passed{background:#def4e6;color:#157448}.status-chip.failed{background:#fde5e5;color:#a52f2f}.status-chip.withdrawn{background:#fff0cf;color:#966113}.status-chip.new{background:#e6efff;color:#315a9c}.status-chip.improvement{background:#eee7ff;color:#6142a0}.muted{color:var(--muted)}.switch{position:relative;width:42px;height:24px;display:inline-block}.switch input{opacity:0;width:0;height:0}.switch span{position:absolute;inset:0;border-radius:99px;background:#cdd8d2;transition:.2s}.switch span:after{content:"";position:absolute;width:18px;height:18px;border-radius:50%;background:#fff;top:3px;right:3px;transition:.2s;box-shadow:0 2px 5px rgba(0,0,0,.15)}.switch input:checked+span{background:var(--brand)}.switch input:checked+span:after{transform:translateX(-18px)}
.feature-list{list-style:none;padding:0;margin:0;display:grid;gap:15px}.feature-list li{display:flex;gap:11px;align-items:flex-start}.feature-list li>span{width:28px;height:28px;border-radius:9px;background:#def4e6;color:#167448;display:grid;place-items:center;font-weight:900}.feature-list strong,.feature-list small{display:block}.feature-list small{color:var(--muted);margin-top:3px}.legend{display:flex;gap:12px;color:var(--muted);font-size:11px}.legend span{display:flex;align-items:center;gap:5px}.dot{width:9px;height:9px;border-radius:50%;display:inline-block}.dot.lect{background:#16775b}.dot.tut{background:#c4862a}.dot.online{background:#4a6dc3}.bundle-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:13px}.bundle-card{border:1px solid var(--line);border-radius:16px;padding:14px;background:var(--surface-2)}.bundle-card .bundle-title{display:flex;justify-content:space-between;gap:8px;align-items:center}.bundle-card h4{margin:0}.bundle-parts{display:grid;gap:7px;margin-top:11px}.bundle-part{font-size:12px;background:#fff;padding:8px 9px;border-radius:10px;border:1px solid #e5ece8}.bundle-part strong{display:block}.bundle-part span{color:var(--muted)}
.rule-card{margin-top:18px;background:linear-gradient(145deg,#0f5a46,#14745a);color:#fff;border-radius:18px;padding:18px}.rule-card h4{margin:0 0 12px}.rule-metrics{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.rule-metrics div{background:rgba(255,255,255,.11);border-radius:12px;padding:10px}.rule-metrics span,.rule-metrics strong{display:block}.rule-metrics span{font-size:10px;color:#d8e9e2}.rule-metrics strong{font-size:20px}.rule-card p{font-size:12px;color:#d8e9e2;margin:12px 0 0}.rule-explainer{display:grid;gap:12px}.rule-explainer>div{display:grid;grid-template-columns:34px 1fr;gap:11px;align-items:center}.rule-explainer b{width:34px;height:34px;border-radius:11px;background:var(--brand-soft);color:var(--brand);display:grid;place-items:center}.rule-explainer p{margin:0}.term-timeline{display:flex;gap:7px;overflow:auto;margin-top:18px;padding-bottom:4px}.term-node{min-width:105px;border:1px solid var(--line);border-radius:12px;padding:10px;text-align:center;background:#fff}.term-node.active{border-color:var(--brand);background:var(--brand-soft)}.term-node span,.term-node strong{display:block}.term-node span{font-size:10px;color:var(--muted)}.priority-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.priority{border:1px solid var(--line);border-radius:16px;padding:16px;background:var(--surface-2)}.priority b{display:grid;place-items:center;width:30px;height:30px;border-radius:10px;margin-bottom:14px}.priority strong,.priority span{display:block}.priority span{font-size:11px;color:var(--muted);margin-top:5px}.p1 b{background:#fee0e0;color:#a12d2d}.p2 b{background:#fff0cc;color:#8a5b0c}.p3 b{background:#dff2e8;color:#176e49}.p4 b{background:#eee7ff;color:#6446a0}.policy-tabs{display:flex;gap:8px;margin-bottom:15px}.policy-tab{border:1px solid var(--line);background:#fff;border-radius:11px;padding:9px 13px;font-weight:800}.policy-tab.active{background:var(--brand);color:#fff;border-color:var(--brand)}.policy-panel{display:none}.policy-panel.active{display:block}.policy-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.policy-box{padding:14px;border:1px solid var(--line);border-radius:15px;background:var(--surface-2)}.policy-box h4{margin:0 0 8px}.policy-box p{margin:3px 0;color:var(--muted);font-size:12px}
.planner-controls{position:sticky;top:8px;z-index:6}.eligibility-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin:18px 0}.eligibility-card{padding:14px;border-radius:15px;border:1px solid var(--line);background:#fff}.eligibility-card strong{display:block;font-size:23px}.eligibility-card span{color:var(--muted);font-size:11px}.plans-container{display:grid;gap:20px}.plan-card{background:#fff;border:1px solid var(--line);border-radius:22px;box-shadow:var(--shadow);overflow:hidden}.plan-head{padding:18px 20px;background:linear-gradient(135deg,#0f5a46,#16775b);color:#fff;display:flex;justify-content:space-between;gap:15px;align-items:flex-start}.plan-head h3{margin:0}.plan-head p{margin:5px 0 0;color:#d9e9e2;font-size:12px}.plan-badge{background:var(--lime);color:#14382b;border-radius:999px;padding:6px 11px;font-size:11px;font-weight:900}.plan-body{padding:18px 20px}.plan-stats{display:grid;grid-template-columns:repeat(5,1fr);gap:9px;margin-bottom:15px}.plan-stat{background:var(--surface-2);border-radius:12px;padding:10px}.plan-stat span,.plan-stat strong{display:block}.plan-stat span{font-size:10px;color:var(--muted)}.plan-stat strong{font-size:17px}.plan-courses{display:grid;gap:9px}.plan-course{display:grid;grid-template-columns:1fr auto auto;gap:12px;align-items:center;border:1px solid var(--line);border-radius:14px;padding:12px}.plan-course h4{margin:0}.plan-course p{margin:3px 0 0;color:var(--muted);font-size:11px}.course-hours{font-weight:900}.reason-list{margin:14px 0 0;padding:12px 18px;background:#f7faf8;border-radius:13px;color:#4e5f56;font-size:12px}.schedule-grid{margin-top:17px;display:grid;grid-template-columns:82px repeat(6,1fr);border:1px solid var(--line);border-radius:14px;overflow:auto;min-width:850px}.schedule-grid>div{min-height:44px;border-left:1px solid var(--line);border-bottom:1px solid var(--line);padding:6px;font-size:10px}.schedule-grid .head{background:#f0f6f3;font-weight:900;text-align:center}.schedule-grid .time{background:#f8faf9;font-weight:800;text-align:center}.schedule-event{border-radius:7px;background:#dff2e8;color:#145d40;padding:4px!important;font-weight:800}.plan-actions{display:flex;gap:9px;justify-content:flex-end;margin-top:16px}.warning-box{border:1px solid #f0d49b;background:#fff8e8;color:#7e5810;border-radius:14px;padding:12px;margin-top:12px;font-size:12px}
.toast-wrap{position:fixed;bottom:25px;left:25px;display:grid;gap:9px;z-index:100}.toast{background:#173d31;color:#fff;padding:11px 15px;border-radius:13px;box-shadow:0 12px 30px rgba(0,0,0,.18);animation:toastin .2s ease}.toast.error{background:#8f3030}.toast.warn{background:#8a6317}@keyframes toastin{from{transform:translateY(10px);opacity:0}to{transform:none;opacity:1}}.mobile-nav{display:none}
@media(max-width:1100px){.app-shell{grid-template-columns:220px 1fr}.main{padding:0 20px 45px}.kpi-grid{grid-template-columns:repeat(2,1fr)}.form-grid.four{grid-template-columns:repeat(2,1fr)}.bundle-grid,.policy-grid{grid-template-columns:repeat(2,1fr)}.priority-grid{grid-template-columns:repeat(2,1fr)}.hero h2{font-size:30px}}
@media(max-width:760px){body{padding-bottom:72px}.app-shell{display:block}.sidebar{display:none}.main{padding:0 12px 26px}.topbar{height:auto;padding:18px 4px 12px;align-items:flex-start}.topbar h1{font-size:25px}.top-actions .ghost{display:none}.top-actions .primary{padding:10px 12px;font-size:12px}.hero{grid-template-columns:1fr;min-height:auto;padding:25px 20px}.hero h2{font-size:28px}.hero-orbit{display:none}.grid.two,.form-grid,.form-grid.four{grid-template-columns:1fr}.span-2{grid-column:auto}.kpi-grid{grid-template-columns:repeat(2,1fr);gap:10px}.kpi{padding:14px}.kpi strong{font-size:22px}.flow{display:grid}.flow i{display:none}.profile-summary{grid-template-columns:1fr}.profile-item.wide{grid-column:auto}.card{padding:16px;border-radius:18px}.card-head{flex-direction:column}.filters{width:100%;display:grid;grid-template-columns:1fr 1fr}.filters input{min-width:0}.bundle-grid,.policy-grid,.priority-grid,.eligibility-strip{grid-template-columns:1fr}.rule-metrics{grid-template-columns:1fr}.plan-stats{grid-template-columns:repeat(2,1fr)}.plan-course{grid-template-columns:1fr auto}.plan-course .status-chip{grid-column:1/-1;width:max-content}.planner-controls{position:static}.mobile-nav{display:grid;grid-template-columns:repeat(5,1fr);position:fixed;bottom:0;left:0;right:0;background:#fff;border-top:1px solid var(--line);z-index:50;padding:7px 4px calc(7px + env(safe-area-inset-bottom));box-shadow:0 -10px 25px rgba(0,0,0,.06)}.mobile-nav button{border:0;background:transparent;color:#718078;display:grid;gap:2px;place-items:center;font-size:18px}.mobile-nav button span{font-size:9px}.mobile-nav button.active{color:var(--brand)}.toast-wrap{left:12px;right:12px;bottom:84px}.toast{text-align:center}.legend{flex-wrap:wrap}.hero-actions{flex-direction:column}.hero-actions button{width:100%}}
@media print{.sidebar,.topbar,.mobile-nav,.planner-controls,.plan-actions,.eligibility-strip{display:none!important}.app-shell{display:block}.main{padding:0}.view{display:none!important}#view-planner{display:block!important}.plan-card{box-shadow:none;break-inside:avoid}.plans-container{display:block}.plan-card{margin-bottom:20px}}
