/* IT-CIL v2 — dashboard component classes (teacher + admin + builder) */

/* mission banner */
.t-mission{ position:relative; overflow:hidden; border-radius:var(--r4); padding:22px 24px;
  background:linear-gradient(135deg,var(--pine-dark),var(--pine-deep)); box-shadow:var(--sh-2); }
.t-mission-bg{ position:absolute; top:-60px; right:-40px; width:240px; height:240px; border-radius:50%;
  background:radial-gradient(circle,rgba(91,106,160,.28),transparent 65%); }

@media(max-width:860px){ .t-ov-grid{ grid-template-columns:1fr!important; } }

.t-quick{ display:flex; align-items:center; gap:9px; padding:13px 14px; border:1.5px solid var(--line); border-radius:var(--r2);
  background:var(--surface); color:var(--ink-2); font-family:var(--sans); font-weight:600; font-size:.84rem; cursor:pointer; text-align:left; transition:.15s; }
.t-quick:hover{ border-color:var(--accent); color:var(--accent-dark); background:var(--accent-soft); transform:translateY(-1px); }
.t-quick .ph{ font-size:1.3rem; color:var(--accent); }

/* core course rows */
.t-course{ display:flex; gap:16px; align-items:center; padding:14px; background:var(--surface); border:1px solid var(--line);
  border-radius:var(--r3); box-shadow:var(--sh-1); transition:.18s; }
.t-course:hover{ box-shadow:var(--sh-2); transform:translateY(-2px); border-color:color-mix(in srgb,var(--terra) 22%,var(--line)); }
.t-course-thumb{ position:relative; width:128px; aspect-ratio:16/10; flex-shrink:0; border-radius:var(--r2); overflow:hidden;
  background:radial-gradient(ellipse at 30% 30%, hsl(var(--hue),62%,58%) 0%, transparent 55%), linear-gradient(135deg, hsl(var(--hue),52%,32%), hsl(calc(var(--hue) + 28),56%,48%)); }
.t-play{ position:absolute; inset:0; margin:auto; width:40px; height:40px; border-radius:50%; background:rgba(255,253,248,.94); color:var(--pine-deep);
  display:flex; align-items:center; justify-content:center; font-size:1.1rem; }
.t-lock{ position:absolute; inset:0; background:rgba(31,36,51,.5); display:flex; align-items:center; justify-content:center; color:#fff; font-size:1.3rem; }
.t-num{ width:30px; height:30px; border-radius:9px; flex-shrink:0; background:var(--terra-soft); color:var(--terra-dark);
  display:inline-flex; align-items:center; justify-content:center; font-weight:700; font-size:.9rem; font-family:var(--serif); }
@media(max-width:560px){ .t-course-thumb{ width:92px; } }

/* my lessons grid */
.t-mylessons{ display:grid; grid-template-columns:repeat(3,1fr); gap:16px; }
@media(max-width:920px){ .t-mylessons{ grid-template-columns:repeat(2,1fr); } }
@media(max-width:600px){ .t-mylessons{ grid-template-columns:1fr; } }
.t-ml-card{ background:var(--surface); border:1px solid var(--line); border-radius:var(--r3); overflow:hidden; box-shadow:var(--sh-1); transition:.18s; }
.t-ml-card:hover{ box-shadow:var(--sh-2); transform:translateY(-2px); }
.t-ml-thumb{ position:relative; aspect-ratio:16/9; display:flex; align-items:center; justify-content:center; font-size:2rem; color:rgba(255,255,255,.9);
  background:radial-gradient(ellipse at 30% 30%, hsl(var(--hue),56%,56%) 0%, transparent 55%), linear-gradient(135deg, hsl(var(--hue),48%,34%), hsl(calc(var(--hue) + 26),52%,48%)); }
.t-ml-views{ position:absolute; right:9px; bottom:9px; background:rgba(31,36,51,.7); color:#fff; font-size:.68rem; font-weight:600; padding:2px 8px; border-radius:5px; }

/* builder */
.bld-banner{ display:flex; align-items:center; gap:9px; padding:11px 15px; border-radius:var(--r2); background:var(--accent-soft);
  color:var(--accent-dark); font-size:.84rem; margin-bottom:18px; }
.bld-banner .ph{ font-size:1.2rem; flex-shrink:0; }
.bld-banner b{ font-weight:700; }

.stepbar{ display:flex; align-items:center; margin-bottom:20px; }
.stepbar .st{ display:flex; align-items:center; gap:10px; }
.stepbar .st .dot{ width:34px; height:34px; border-radius:50%; flex-shrink:0; display:flex; align-items:center; justify-content:center;
  font-weight:700; font-size:.9rem; background:var(--paper-2); color:var(--ink-3); border:2px solid transparent; font-family:var(--serif); transition:.2s; }
.stepbar .st .stl{ font-size:.84rem; font-weight:600; color:var(--ink-3); white-space:nowrap; }
.stepbar .st.on .dot{ background:var(--accent); color:#fff; box-shadow:0 0 0 4px var(--accent-soft); }
.stepbar .st.on .stl{ color:var(--accent-dark); }
.stepbar .st.done .dot{ background:var(--ok); color:#fff; }
.stepbar .st.done .stl{ color:var(--ink); }
.stepbar .ln{ flex:1; height:2px; background:var(--line); margin:0 10px; min-width:16px; }
.stepbar .ln.done{ background:var(--ok); }
@media(max-width:680px){ .stepbar .stl{ display:none; } .stepbar .st{ flex:0 0 auto; } .stepbar .ln{ min-width:10px; } }

.canvas{ display:flex; flex-direction:column; gap:12px; }
.block{ border:1.5px solid var(--line); border-radius:var(--r3); background:var(--surface); padding:14px 16px; transition:.15s; }
.block:hover{ border-color:color-mix(in srgb,var(--accent) 25%,var(--line)); box-shadow:var(--sh-1); }
.block-h{ display:flex; align-items:center; gap:9px; font-weight:600; font-size:.88rem; margin-bottom:11px; color:var(--ink-2); }
.block-h .ph{ color:var(--accent); font-size:1.1rem; }
.block-h .rm{ margin-left:auto; color:var(--ink-4); cursor:pointer; transition:.15s; }
.block-h .rm:hover{ color:var(--bad); }
.ghost{ border:2px dashed var(--line); border-radius:var(--r3); padding:14px; text-align:center; color:var(--ink-3); font-size:.84rem; background:var(--surface-2); }
.pal{ display:flex; flex-direction:column; gap:8px; }
.pal-btn{ display:inline-flex; align-items:center; gap:8px; padding:10px 14px; border:1.5px dashed var(--line); border-radius:var(--pill);
  background:var(--surface); color:var(--ink-2); font-size:.84rem; font-weight:600; cursor:pointer; font-family:var(--sans); transition:.15s; }
.pal-btn:hover{ border-color:var(--accent); color:var(--accent-dark); border-style:solid; background:var(--accent-soft); }
.pal-btn .ph{ font-size:1.1rem; }

.tpl-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:15px; }
@media(max-width:760px){ .tpl-grid{ grid-template-columns:1fr; } }
.tpl{ border:2px solid var(--line); border-radius:var(--r3); overflow:hidden; cursor:pointer; background:var(--surface); transition:.18s; text-align:left; padding:0; font-family:var(--sans); }
.tpl:hover{ border-color:var(--accent); transform:translateY(-3px); box-shadow:var(--sh-2); }
.tpl.on{ border-color:var(--accent); box-shadow:0 0 0 3px var(--accent-soft); }
.tpl-top{ aspect-ratio:16/9; display:flex; align-items:center; justify-content:center; color:rgba(255,255,255,.92); font-size:2rem; position:relative;
  background:linear-gradient(135deg, hsl(var(--hue),48%,34%), hsl(calc(var(--hue) + 28),52%,48%)); }
.tpl-tick{ position:absolute; top:8px; right:8px; width:24px; height:24px; border-radius:50%; background:var(--accent); color:#fff; display:none; align-items:center; justify-content:center; font-size:.75rem; }
.tpl.on .tpl-tick{ display:flex; }
.tpl-body{ padding:12px 14px; }
.tpl-body h6{ margin:0 0 4px; font-size:.92rem; font-family:var(--serif); }
.tpl-body p{ margin:0; font-size:.76rem; color:var(--ink-3); line-height:1.45; }

/* admin chart */
.bars{ display:flex; align-items:stretch; gap:7px; height:168px; }
.bars > div{ flex:1; display:flex; flex-direction:column; justify-content:flex-end; }
.bars > div > i{ display:block; width:100%; border-radius:5px 5px 0 0; }

/* small avatar in user table */
.usr-av-sm{ width:30px; height:30px; border-radius:9px; flex-shrink:0; background:linear-gradient(135deg,var(--terra),var(--terra-dark));
  color:#fff; font-weight:700; font-size:.72rem; display:inline-flex; align-items:center; justify-content:center; font-family:var(--serif); }

/* density: compact tightens dashboard paddings */body[data-density="compact"] .page{ padding-top:18px; padding-bottom:48px; }
body[data-density="compact"] .card-pad{ padding:15px 16px; }
body[data-density="compact"] .stat{ padding:13px 15px; }
body[data-density="compact"] .stat .ic{ width:36px; height:36px; font-size:1.1rem; margin-bottom:9px; }
body[data-density="compact"] .stat .n{ font-size:1.5rem; }
body[data-density="compact"] .tbl td{ padding:9px 16px; }
body[data-density="compact"] .t-course{ padding:11px; gap:13px; }
body[data-density="compact"] .ph-head{ margin-bottom:14px; }

/* CMS rows */
.cms-row{ display:grid; grid-template-columns:200px 1fr; gap:14px; align-items:start; }
@media(max-width:680px){ .cms-row{ grid-template-columns:1fr; gap:6px; } }
.cms-meta label{ display:block; font-size:.84rem; font-weight:600; color:var(--ink-2); }
.cms-meta code{ font-size:.68rem; color:var(--ink-4); font-family:var(--mono,monospace); background:var(--surface-2); padding:1px 6px; border-radius:5px; display:inline-block; margin-top:4px; }

/* notification popover */
.pop-scrim{ position:fixed; inset:0; z-index:50; }
.pop{ position:absolute; top:48px; right:0; z-index:51; width:300px; background:var(--surface); border:1px solid var(--line);
  border-radius:var(--r3); box-shadow:var(--sh-3); overflow:hidden; animation:lmin .18s ease; }
.pop-head{ font-family:var(--serif); font-weight:600; font-size:.95rem; padding:13px 16px; border-bottom:1px solid var(--line-2); }
.pop-item{ display:flex; gap:11px; align-items:flex-start; padding:12px 16px; border-bottom:1px solid var(--line-2); }
.pop-item:last-child{ border-bottom:none; }
.pop-item:hover{ background:var(--surface-2); }
.pop-ic{ width:30px; height:30px; border-radius:9px; flex-shrink:0; color:#fff; display:flex; align-items:center; justify-content:center; font-size:.9rem; }

/* comments */
.cmt{ display:flex; gap:11px; }
.cmt-av{ width:38px; height:38px; border-radius:50%; flex-shrink:0; background:var(--surface-2); border:1px solid var(--line); color:var(--ink-3); display:flex; align-items:center; justify-content:center; font-size:1.05rem; }
.cmt-head{ display:flex; align-items:center; gap:9px; }
.cmt-head b{ font-size:.88rem; }
.cmt-text{ margin:3px 0 0; font-size:.88rem; color:var(--ink-2); line-height:1.55; }
.cmt-reply{ margin-top:9px; padding:10px 13px; border-radius:var(--r2); background:var(--accent-soft,var(--pine-soft)); border-left:3px solid var(--pine); }
.cmt-reply p{ margin:0; font-size:.86rem; color:var(--pine-dark); line-height:1.55; }
.cmt-held{ border:1px dashed var(--warn); background:var(--warn-soft); border-radius:var(--r2); padding:12px 14px; }
.flag-word{ background:var(--bad-soft); color:var(--bad-ink); border-radius:5px; padding:0 5px; font-weight:600; }
.word-tag{ display:inline-flex; align-items:center; gap:6px; padding:5px 11px; border-radius:var(--pill); background:var(--bad-soft); color:var(--bad-ink); font-size:.82rem; font-weight:600; }
.word-tag i{ cursor:pointer; opacity:.7; }
.word-tag i:hover{ opacity:1; }

/* SERP preview */
.serp{ background:var(--surface); border:1px solid var(--line); border-radius:var(--r3); padding:14px 16px; box-shadow:var(--sh-1); }
.serp-url{ display:flex; align-items:center; gap:7px; font-size:.78rem; color:var(--ink-2); margin-bottom:4px; }
.serp-fav{ width:18px; height:18px; border-radius:50%; background:var(--surface-2); display:inline-flex; align-items:center; justify-content:center; font-size:.7rem; }
.serp-url .ph{ margin-left:auto; color:var(--ink-4); }
.serp-title{ color:#1a0dab; font-size:1.1rem; line-height:1.3; margin-bottom:3px; font-family:var(--serif); }
.serp-desc{ font-size:.82rem; color:var(--ink-2); line-height:1.5; }
.serp-og{ aspect-ratio:1200/360; background:linear-gradient(135deg,var(--pine-dark),var(--pine-deep)); border-radius:var(--r2); display:flex; align-items:center; justify-content:center; color:rgba(255,255,255,.4); font-size:2rem; margin-bottom:2px; }

/* Google button */
.gbtn{ display:flex; align-items:center; justify-content:center; gap:11px; width:100%; padding:.7rem 1rem; border:1.5px solid var(--line);
  border-radius:var(--r2); background:var(--surface); color:var(--ink); font-family:var(--sans); font-size:.92rem; font-weight:600; cursor:pointer; transition:.15s; }
.gbtn:hover{ border-color:var(--ink-3); box-shadow:var(--sh-1); background:#fff; }
.gbtn-ic{ display:flex; }
.lm-or{ display:flex; align-items:center; gap:12px; margin:14px 0; color:var(--ink-4); font-size:.78rem; }
.lm-or::before, .lm-or::after{ content:''; flex:1; height:1px; background:var(--line); }
.gacct{ display:flex; align-items:center; gap:12px; padding:12px 14px; border-radius:var(--r2); background:var(--surface-2); border:1px solid var(--line); }
.gacct-av{ width:40px; height:40px; border-radius:50%; flex-shrink:0; background:linear-gradient(135deg,var(--pine),var(--pine-dark)); color:#fff; font-weight:700; font-family:var(--serif); display:flex; align-items:center; justify-content:center; }
.gacct b{ font-size:.88rem; display:block; }

.grid-name{ display:grid; grid-template-columns:130px 1fr 1fr 1fr; gap:14px; }
@media(max-width:680px){ .grid-name{ grid-template-columns:1fr 1fr; } }

/* profile */
.prof-hero{ position:relative; overflow:hidden; padding:0; }
.prof-hero-bg{ position:absolute; inset:0; background:linear-gradient(135deg,var(--terra-dark),#c8431a); }
.prof-hero-bg::after{ content:''; position:absolute; top:-60px; right:-40px; width:220px; height:220px; border-radius:50%; background:radial-gradient(circle,rgba(255,255,255,.14),transparent 65%); }
.prof-hero-row{ position:relative; z-index:1; display:flex; align-items:center; gap:18px; padding:24px 26px; }
.prof-avatar{ width:74px; height:74px; border-radius:20px; flex-shrink:0; background:rgba(255,255,255,.18); border:2px solid rgba(255,255,255,.3); color:#fff; font-family:var(--serif); font-weight:700; font-size:1.7rem; display:flex; align-items:center; justify-content:center; }
.prof-grid{ display:flex; flex-direction:column; gap:14px; }
.prof-item{ display:flex; gap:12px; align-items:flex-start; }
.prof-ic{ width:36px; height:36px; border-radius:10px; flex-shrink:0; background:var(--accent-soft,var(--terra-soft)); color:var(--accent-dark,var(--terra-dark)); display:flex; align-items:center; justify-content:center; font-size:1.05rem; }
.prof-item > div > div{ font-size:.92rem; font-weight:500; margin-top:1px; }
