/* ============ C.I.C. Learning Portal — design system (v0.25.0) ============ */
:root{
  --teal:#0B4D4A; --teal-d:#073634; --teal-l:#1f8f89; --teal-xxl:#e8f4f3;
  --gold:#D4A820; --gold-d:#a87f12; --gold-l:#f0c44a;
  --aqua:#0fa3a0; --blue:#2f74d0; --violet:#7c5cff; --rose:#e0567a; --green:#1f9d72;
  --ink:#142a28; --ink-2:#3a4f4d; --ink-3:#7a8c8a;
  --line:#e3edec; --bg:#eef4f3; --card:#ffffff;
  --ok:#1f9d72; --bad:#c0392b; --warn:#d98b1f;
  --r:18px; --r-sm:13px; --shadow:0 3px 14px rgba(7,54,52,.07); --shadow-lg:0 18px 50px rgba(7,54,52,.20);
  --sans:Arial, Helvetica, "Segoe UI", Roboto, system-ui, sans-serif;
}
*{box-sizing:border-box}
.cic-portal-body{margin:0;background:var(--bg);font-family:var(--sans);color:var(--ink);-webkit-font-smoothing:antialiased;
  background-image:radial-gradient(900px 380px at 0% -5%,rgba(15,163,160,.10),transparent),radial-gradient(700px 360px at 100% 0%,rgba(212,168,32,.10),transparent)}

/* ---------- Auth (login / OTP) ---------- */
.cic-auth-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px}
.cic-auth-card{width:100%;max-width:430px;background:var(--card);border-radius:24px;box-shadow:var(--shadow-lg);padding:0 0 30px;border:1px solid var(--line);overflow:hidden}
.cic-auth-head{text-align:center;padding:30px 30px 22px;background:linear-gradient(135deg,var(--teal),var(--teal-l));position:relative;overflow:hidden}
.cic-auth-head:after{content:"";position:absolute;right:-30px;top:-30px;width:130px;height:130px;border-radius:50%;background:rgba(212,168,32,.28)}
.cic-logo{font-weight:800;font-size:23px;color:#fff;line-height:1.15;letter-spacing:.2px;position:relative}
.cic-rule{height:4px;width:56px;background:var(--gold);margin:12px auto 0;border-radius:3px;position:relative}
.cic-tag{color:#d6efed;font-size:12.5px;margin-top:10px;position:relative;letter-spacing:.02em}
.cic-auth-title{font-size:20px;font-weight:800;color:var(--ink);text-align:center;margin:24px 30px 14px}
.cic-form{display:flex;flex-direction:column;gap:4px;padding:0 30px}
.cic-form label{font-size:13px;font-weight:700;color:var(--ink-2);margin-top:12px}
.cic-form input[type=text],.cic-form input[type=password],.cic-form input[type=email]{
  padding:13px 15px;border:1.5px solid var(--line);border-radius:12px;font-size:15px;font-family:inherit;transition:.15s;background:#fbfdfd}
.cic-form input:focus{outline:none;border-color:var(--teal-l);box-shadow:0 0 0 4px rgba(31,143,137,.15);background:#fff}
.cic-check{display:flex;align-items:center;gap:8px;font-weight:500;font-size:13.5px;margin-top:14px;color:var(--ink-2)}
.cic-check input{width:auto}
.cic-otp{letter-spacing:14px;text-align:center;font-size:28px;font-weight:800;padding:15px;color:var(--teal-d)}
.cic-btn{border:none;border-radius:13px;padding:14px 18px;font-size:15px;font-weight:800;cursor:pointer;font-family:inherit;transition:.18s;margin-top:20px;letter-spacing:.02em}
.cic-btn-pri{background:linear-gradient(135deg,var(--teal),var(--teal-l));color:#fff;box-shadow:0 8px 18px rgba(11,77,74,.25)}
.cic-btn-pri:hover{transform:translateY(-1px);box-shadow:0 12px 22px rgba(11,77,74,.32)}
.cic-link{background:none;border:none;color:var(--teal);font-weight:700;cursor:pointer;font-size:13.5px;font-family:inherit;text-decoration:none}
.cic-link:hover{color:var(--teal-d);text-decoration:underline}
.cic-resend{text-align:center;margin-top:12px;padding:0 30px}
.cic-note{font-size:12.5px;color:var(--ink-3);text-align:center;margin:16px 30px 0;line-height:1.55}
.cic-alert{border-radius:11px;padding:11px 14px;font-size:13.5px;margin:0 30px 8px}
.cic-bad{background:#fdecea;color:#a02418;border:1px solid #f6c9c2}
.cic-ok{background:#e8f6ef;color:#13794f;border:1px solid #bfe6d2}
.cic-auth-foot{text-align:center;margin-top:24px;font-size:12.5px;color:var(--ink-3)}
.cic-auth-foot a{color:var(--teal);text-decoration:none;font-weight:700}
.cic-legal{text-align:center;font-size:11px;color:var(--ink-3);margin-top:10px;padding:0 20px}
.cic-auth-head.cic-cream{background:#f4f0e5}
.cic-auth-img{max-width:300px;width:88%;height:auto;display:block;margin:0 auto}

/* ============ App shell — StudyGroup-inspired (white top bar + teal nav) ============ */
.cic-app{min-height:100vh;display:flex;flex-direction:column}

/* White top bar: logo | Learning Portal ............ lang · user · sign out */
.cic-topbar{display:flex;align-items:center;gap:14px;background:#fff;border-bottom:1px solid var(--line);
  padding:0 26px;height:66px;position:sticky;top:0;z-index:45;box-shadow:0 1px 0 rgba(7,54,52,.04)}
.cic-burger{display:none;background:none;border:none;color:var(--teal-d);cursor:pointer;padding:6px;border-radius:8px}
.cic-tb-brand{display:flex;align-items:center;gap:14px;text-decoration:none}
.cic-tb-logo{height:36px;width:auto;display:block}
.cic-tb-div{width:1px;height:30px;background:var(--line)}
.cic-tb-label{font-size:18px;font-weight:800;color:var(--teal-d);letter-spacing:.2px}
.cic-tb-right{margin-left:auto;display:flex;align-items:center;gap:16px}
.cic-lang{color:var(--teal);text-decoration:none;font-size:12px;font-weight:800;border:1.5px solid #cdddda;border-radius:8px;padding:5px 10px;transition:.15s}
.cic-lang:hover{background:var(--teal-xxl);border-color:var(--teal-l)}
.cic-tb-user{display:flex;align-items:center;gap:10px}
.cic-avatar{width:38px;height:38px;border-radius:50%;background:linear-gradient(135deg,var(--teal),var(--teal-l));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:16px;box-shadow:0 3px 9px rgba(11,77,74,.28)}
.cic-tb-usermeta{display:flex;flex-direction:column;line-height:1.15}
.cic-tb-name{font-weight:800;font-size:14px;color:var(--ink)}
.cic-tb-role{font-size:11px;font-weight:700;color:var(--gold-d);text-transform:uppercase;letter-spacing:.04em}
.cic-logout{display:inline-flex;align-items:center;color:var(--ink-2);text-decoration:none;font-size:13.5px;font-weight:700;border:1.5px solid var(--line);border-radius:9px;padding:8px 14px;transition:.15s}
.cic-logout:hover{border-color:var(--bad);color:var(--bad)}

/* Teal horizontal nav bar */
.cic-navbar{background:linear-gradient(90deg,var(--teal-d),var(--teal));position:sticky;top:66px;z-index:44;box-shadow:0 3px 16px rgba(7,54,52,.18)}
.cic-navinner{display:flex;align-items:stretch;gap:2px;max-width:1240px;margin:0 auto;padding:0 14px;overflow-x:auto;scrollbar-width:none}
.cic-navinner::-webkit-scrollbar{display:none}
.cic-navbar a{position:relative;display:inline-flex;align-items:center;gap:7px;white-space:nowrap;color:#d8ece9;text-decoration:none;font-weight:700;font-size:14px;padding:16px 16px;border-bottom:3px solid transparent;transition:.14s}
.cic-navbar a:hover{color:#fff;background:rgba(255,255,255,.07)}
.cic-navbar a.on{color:#fff;border-bottom-color:var(--gold)}
.cic-soon{font-size:9.5px;font-weight:800;background:rgba(255,255,255,.16);color:#eaf6f4;padding:2px 7px;border-radius:20px;text-transform:uppercase;letter-spacing:.03em}
.cic-overlay{display:none;position:fixed;inset:0;background:rgba(7,30,29,.45);z-index:43}
.cic-overlay.show{display:block}

/* Main content area */
.cic-main{padding:28px 26px 56px;max-width:1240px;margin:0 auto;width:100%}

/* ---------- Hero banner (teal panel + photo, angled divider) ---------- */
.cic-banner{position:relative;display:flex;align-items:stretch;background:linear-gradient(125deg,var(--teal-d),var(--teal) 60%,var(--teal-l));
  border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow);min-height:236px}
.cic-banner-text{flex:1 1 56%;padding:38px 40px;color:#fff;display:flex;flex-direction:column;justify-content:center;position:relative;z-index:2}
.cic-banner-eyebrow{font-size:13px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:var(--gold-l);margin:0 0 8px}
.cic-banner-text h1{font-size:2.15rem;font-weight:800;line-height:1.12;margin:0 0 12px;letter-spacing:.2px}
.cic-banner-text p{margin:0;color:#d6efed;font-size:15px;line-height:1.55;max-width:460px}
.cic-banner-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:22px}
.cic-bbtn{display:inline-flex;align-items:center;gap:7px;border-radius:30px;padding:12px 26px;font-size:14px;font-weight:800;text-decoration:none;transition:.16s;border:1.6px solid rgba(255,255,255,.7);color:#fff}
.cic-bbtn:hover{background:#fff;color:var(--teal-d);transform:translateY(-1px)}
.cic-bbtn.pri{background:var(--gold);border-color:var(--gold);color:var(--teal-d);box-shadow:0 8px 18px rgba(212,168,32,.3)}
.cic-bbtn.pri:hover{background:var(--gold-l);color:var(--teal-d)}
.cic-banner-art{flex:1 1 44%;position:relative;background-size:cover;background-position:center;
  background-image:linear-gradient(135deg,var(--teal-l),var(--aqua));clip-path:polygon(14% 0,100% 0,100% 100%,0 100%)}
.cic-banner-art:before{content:"";position:absolute;right:-40px;bottom:-60px;width:230px;height:230px;border-radius:50%;background:rgba(212,168,32,.22)}
.cic-banner-art:after{content:"";position:absolute;right:70px;top:-40px;width:120px;height:120px;border-radius:50%;background:rgba(255,255,255,.10)}

/* Page-header panel (used by inner views) */
.cic-hero{background:linear-gradient(125deg,var(--teal-d),var(--teal) 55%,var(--teal-l));color:#fff;border-radius:var(--r);padding:26px 30px;box-shadow:var(--shadow);position:relative;overflow:hidden}
.cic-hero:before{content:"";position:absolute;right:-30px;bottom:-50px;width:200px;height:200px;border-radius:50%;background:rgba(212,168,32,.20)}
.cic-hero:after{content:"";position:absolute;right:90px;top:-50px;width:120px;height:120px;border-radius:50%;background:rgba(255,255,255,.07)}
.cic-hero h1{font-size:1.6rem;font-weight:800;margin:0;letter-spacing:.3px;position:relative}
.cic-hero p{margin:7px 0 0;color:#daf0ee;font-size:14.5px;max-width:660px;position:relative;line-height:1.55}

/* ---------- Cards ---------- */
.cic-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(270px,1fr));gap:18px;margin-top:24px}
.cic-card{background:var(--card);border:1px solid var(--line);border-radius:var(--r-sm);padding:20px 22px;box-shadow:var(--shadow);position:relative;overflow:hidden;transition:.18s}
.cic-card:hover{transform:translateY(-3px);box-shadow:0 12px 30px rgba(7,54,52,.13)}
.cic-card:before{content:"";position:absolute;left:0;top:0;bottom:0;width:5px;background:var(--teal)}
.cic-cards .cic-card:nth-child(5n+1):before{background:var(--teal)}
.cic-cards .cic-card:nth-child(5n+2):before{background:var(--gold)}
.cic-cards .cic-card:nth-child(5n+3):before{background:var(--blue)}
.cic-cards .cic-card:nth-child(5n+4):before{background:var(--violet)}
.cic-cards .cic-card:nth-child(5n+5):before{background:var(--green)}
.cic-card-top{font-weight:800;color:var(--ink);font-size:1.06rem;display:flex;align-items:center;justify-content:space-between;gap:8px}
.cic-card-badge{font-size:10.5px;font-weight:800;background:linear-gradient(135deg,var(--gold),var(--gold-l));color:var(--teal-d);padding:3px 10px;border-radius:20px;text-transform:uppercase;letter-spacing:.03em}
.cic-card p{margin:10px 0 0;color:var(--ink-3);font-size:13.5px;line-height:1.55}
.cic-card-link{position:absolute;inset:0}

/* Status pills (StudyGroup-style) */
.cic-pill{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:800;padding:5px 13px;border-radius:30px;letter-spacing:.01em}
.cic-pill:before{content:"";width:7px;height:7px;border-radius:50%;background:currentColor;opacity:.8}
.cic-pill.ok{background:#e3f5ec;color:#13794f}
.cic-pill.warn{background:#fdeede;color:#b3730c}
.cic-pill.info{background:var(--teal-xxl);color:var(--teal)}
.cic-pill.neutral{background:#eef2f1;color:#5b6c6a}

/* Section heading + meta rows used across views */
.cic-sec-h{font-size:1.25rem;font-weight:800;color:var(--teal-d);margin:26px 0 4px}
.cic-meta{display:flex;align-items:center;gap:7px;font-size:13px;color:var(--ink-2);margin-top:7px}
.cic-meta b{color:var(--ink)}

.cic-statusbar{margin-top:24px;background:linear-gradient(135deg,#fff,#f3faf9);border:1px solid var(--line);border-radius:var(--r-sm);padding:13px 18px;font-size:13px;color:var(--ink-2);display:flex;align-items:center;gap:10px;box-shadow:var(--shadow)}
.cic-dot{width:10px;height:10px;border-radius:50%;display:inline-block}
.cic-dot.ok{background:var(--ok);box-shadow:0 0 0 4px rgba(31,157,114,.18)}

@media(max-width:960px){
  .cic-topbar{padding:0 16px;height:60px}
  .cic-tb-label{display:none}
  .cic-tb-div{display:none}
  .cic-burger{display:flex}
  .cic-tb-usermeta{display:none}
  .cic-navbar{position:fixed;left:0;top:0;bottom:0;width:264px;z-index:46;background:linear-gradient(160deg,var(--teal-d),var(--teal));
    transform:translateX(-100%);transition:.25s;box-shadow:none;padding-top:14px}
  .cic-navbar.open{transform:none;box-shadow:var(--shadow-lg)}
  .cic-navinner{flex-direction:column;align-items:stretch;gap:2px;max-width:none;padding:8px 10px;overflow:visible}
  .cic-navbar a{padding:13px 16px;border-bottom:none;border-radius:10px}
  .cic-navbar a.on{background:rgba(255,255,255,.14);border-bottom:none}
  .cic-navbar a:hover{background:rgba(255,255,255,.10)}
  .cic-main{padding:20px 16px 48px}
  .cic-banner{flex-direction:column;min-height:0}
  .cic-banner-art{min-height:150px;clip-path:none;flex-basis:auto}
  .cic-banner-text{flex-basis:auto;padding:28px 24px}
  .cic-banner-text h1{font-size:1.6rem}
}

/* ---------- Lesson reader + HTML lesson kit ---------- */
.cic-lesson{max-width:820px;background:#fff;border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow);padding:30px 34px;margin-top:6px}
.cic-lesson-title{font-size:1.7rem;font-weight:800;color:var(--teal-d);margin:0 0 16px;letter-spacing:.2px}
.cic-video{margin:0 0 20px}
#cic-lesson-wrap{font-size:15.5px;line-height:1.72;color:var(--ink)}
#cic-lesson-wrap h1,#cic-lesson-wrap h2,#cic-lesson-wrap h3,#cic-lesson-wrap h4{color:var(--teal-d);font-weight:800;line-height:1.25;margin:1.5em 0 .5em}
#cic-lesson-wrap h2{font-size:1.4rem;border-bottom:2px solid var(--teal-xxl);padding-bottom:.25em}
#cic-lesson-wrap h3{font-size:1.18rem}
#cic-lesson-wrap p{margin:0 0 1.1em}
#cic-lesson-wrap a{color:var(--teal);font-weight:600}
#cic-lesson-wrap ul,#cic-lesson-wrap ol{margin:0 0 1.1em 1.3em}
#cic-lesson-wrap li{margin:.3em 0}
#cic-lesson-wrap img{max-width:100%;height:auto;border-radius:12px;margin:.5em 0}
#cic-lesson-wrap blockquote{margin:1.2em 0;padding:12px 18px;border-left:4px solid var(--gold);background:#fffaf0;border-radius:0 10px 10px 0;color:var(--ink-2)}
#cic-lesson-wrap table{width:100%;border-collapse:collapse;margin:1.2em 0;font-size:14.5px}
#cic-lesson-wrap th,#cic-lesson-wrap td{border:1px solid var(--line);padding:9px 12px;text-align:left}
#cic-lesson-wrap th{background:var(--teal);color:#fff;font-weight:700}
#cic-lesson-wrap tr:nth-child(even) td{background:#f7fbfa}
#cic-lesson-wrap code{background:#eef4f3;padding:2px 6px;border-radius:5px;font-size:13.5px}
#cic-lesson-wrap pre{background:#0f2624;color:#e6f3f1;padding:16px;border-radius:12px;overflow:auto;font-size:13px}
#cic-lesson-wrap .cic-callout{border-radius:12px;padding:16px 20px;margin:1.3em 0;border-left:5px solid var(--teal)}
#cic-lesson-wrap .cic-callout h4{margin:0 0 6px;color:var(--teal-d)}
#cic-lesson-wrap .cic-callout.cic-teal{background:var(--teal-xxl);border-left-color:var(--teal)}
#cic-lesson-wrap .cic-callout.cic-gold{background:#fff7e6;border-left-color:var(--gold)}
#cic-lesson-wrap .cic-keybox{background:#f4f9f8;border:1px dashed var(--teal-l);border-radius:10px;padding:12px 16px;margin:1.1em 0}
#cic-lesson-wrap .cic-cols{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin:1.2em 0}
#cic-lesson-wrap .cic-cols>div{background:#f7fbfa;border:1px solid var(--line);border-radius:12px;padding:14px 18px}
#cic-lesson-wrap .cic-summary{background:linear-gradient(135deg,var(--teal-xxl),#fff);border:1px solid var(--line);border-radius:12px;padding:16px 20px;margin:1.4em 0}
#cic-lesson-wrap .cic-summary h4{margin:0 0 8px;color:var(--teal-d)}
#cic-lesson-wrap a.cic-resource{display:inline-block;background:linear-gradient(135deg,var(--gold),var(--gold-l));color:var(--teal-d);font-weight:800;text-decoration:none;padding:11px 20px;border-radius:10px;margin:.6em 0;box-shadow:0 6px 14px rgba(212,168,32,.3)}
@media(max-width:680px){ #cic-lesson-wrap .cic-cols{grid-template-columns:1fr} .cic-lesson{padding:22px 18px} }
