:root {
  --ink: #0a3153;
  --ink-soft: #315d78;
  --muted: #5e7f94;
  --line: #c5d9e6;
  --line-soft: #dcebf3;
  --paper: #ffffff;
  --canvas: #edf6fb;
  --navy: #0f568f;
  --navy-deep: #073b67;
  --green: #208fc6;
  --green-dark: #0f679f;
  --green-soft: #d9f0fb;
  --peach: #48aeda;
  --peach-soft: #e7f7fd;
  --purple: #1d78b5;
  --purple-soft: #dceff8;
  --yellow: #f2bc3f;
  --shadow-sm: 0 10px 28px rgba(8, 59, 103, .12);
  --shadow-lg: 0 26px 80px rgba(8, 59, 103, .24);
  --radius: 18px;
  --sidebar: 248px;
}

* { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
  margin: 0;
  color: var(--ink);
  background: var(--canvas);
  font-family: "Segoe UI", Inter, Arial, sans-serif;
  font-size: 14px;
  line-height: 1.5;
  transition: background .2s ease, color .2s ease;
}

body.theme-dark {
  --ink: #eef8ff;
  --ink-soft: #c8dcec;
  --muted: #95b1c4;
  --line: #2b4a61;
  --line-soft: #1b374c;
  --paper: #10283a;
  --canvas: #071824;
  --navy: #66c8ff;
  --navy-deep: #092236;
  --green: #40b8ee;
  --green-dark: #2294cf;
  --green-soft: #123a52;
  --peach: #5bc4f1;
  --peach-soft: #143247;
  --purple: #79cbff;
  --purple-soft: #183a53;
  --yellow: #ffd166;
  --shadow-sm: 0 12px 34px rgba(0, 0, 0, .28);
  --shadow-lg: 0 30px 90px rgba(0, 0, 0, .48);
  color-scheme: dark;
}

button, input, select, textarea { font: inherit; }
button { cursor: pointer; }
button, input, select, textarea { outline: none; }

.is-hidden { display: none !important; }

.brand {
  display: flex;
  align-items: center;
  gap: 11px;
}

.brand-mark {
  display: grid;
  width: 42px;
  height: 42px;
  padding: 4px;
  border: 1px solid rgba(37, 143, 199, .15);
  border-radius: 12px;
  place-items: center;
  background: white;
  box-shadow: 0 7px 18px rgba(23, 109, 166, .18);
}

.brand-mark img { display: block; width: 100%; height: 100%; object-fit: contain; }
.brand-light .brand-mark { border-color: rgba(255,255,255,.18); background: rgba(255,255,255,.96); }
.brand strong, .brand small { display: block; }
.brand strong { letter-spacing: -.2px; }
.brand small { margin-top: -2px; color: var(--muted); font-size: 10px; }
.brand-light strong { color: white; }
.brand-light small { color: rgba(255, 255, 255, .6); }

.eyebrow {
  display: block;
  color: var(--green-dark);
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 1.3px;
  text-transform: uppercase;
}

.eyebrow-light { color: #8dd1ef; }

h1, h2, h3, p { margin-top: 0; }
h1 { margin-bottom: 8px; font-family: Georgia, "Times New Roman", serif; font-size: clamp(30px, 3vw, 44px); line-height: 1.08; letter-spacing: -.8px; }
h2 { margin-bottom: 5px; font-family: Georgia, "Times New Roman", serif; font-size: 25px; line-height: 1.2; }
h3 { margin-bottom: 5px; font-size: 17px; line-height: 1.25; }
p { color: var(--muted); }

.button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 40px;
  padding: 0 17px;
  border: 1px solid transparent;
  border-radius: 10px;
  font-weight: 700;
  transition: transform .2s ease, box-shadow .2s ease, background .2s ease;
}

.button:hover { transform: translateY(-1px); }
.button-primary { color: white; background: var(--green); box-shadow: 0 7px 18px rgba(42, 167, 125, .2); }
.button-primary:hover { background: var(--green-dark); }
.button-secondary { color: var(--ink); border-color: var(--line); background: white; }
.button-secondary:hover { border-color: #b8c9cd; box-shadow: var(--shadow-sm); }
.button-large { min-height: 51px; border-radius: 12px; font-size: 14px; }
.text-button, .back-link {
  padding: 0;
  border: 0;
  color: var(--green-dark);
  background: transparent;
  font-weight: 700;
}
.back-link { display: block; margin-bottom: 15px; color: var(--muted); font-size: 12px; }
.icon-button {
  position: relative;
  display: grid;
  width: 39px;
  height: 39px;
  padding: 0;
  border: 1px solid var(--line);
  border-radius: 11px;
  place-items: center;
  color: var(--ink-soft);
  background: white;
  font-size: 11px;
  font-weight: 800;
}

.theme-toggle {
  width: auto;
  min-width: 56px;
  padding: 0 11px;
  color: var(--green-dark);
}

.login-screen {
  display: grid;
  min-height: 100vh;
  grid-template-columns: 1.08fr .92fr;
  background: var(--paper);
}

.login-story {
  position: relative;
  display: flex;
  min-height: 100vh;
  padding: 42px clamp(42px, 7vw, 100px);
  flex-direction: column;
  justify-content: space-between;
  overflow: hidden;
  color: white;
  background:
    radial-gradient(circle at 70% 80%, rgba(69, 168, 216, .32), transparent 30%),
    radial-gradient(circle at 0 10%, rgba(255, 255, 255, .08), transparent 27%),
    var(--navy-deep);
}

.login-story::after {
  position: absolute;
  right: -70px;
  bottom: -40px;
  width: 430px;
  height: 430px;
  background: url("assets/alc-logo.png") center / contain no-repeat;
  content: "";
  opacity: .075;
  transform: rotate(-8deg);
}

.login-story::before {
  position: absolute;
  right: -180px;
  bottom: -210px;
  width: 600px;
  height: 600px;
  border: 1px solid rgba(255, 255, 255, .06);
  border-radius: 50%;
  box-shadow: 0 0 0 90px rgba(255, 255, 255, .025), 0 0 0 180px rgba(255, 255, 255, .018);
  content: "";
}

.story-copy { position: relative; z-index: 2; max-width: 650px; }
.story-copy h1 { margin: 18px 0 20px; color: white; font-size: clamp(45px, 6.2vw, 82px); line-height: .98; letter-spacing: -2.5px; }
.story-copy > p { max-width: 520px; color: rgba(255,255,255,.65); font-size: 17px; }
.story-proof { display: flex; gap: 38px; margin-top: 35px; }
.story-proof div { padding-right: 30px; border-right: 1px solid rgba(255,255,255,.14); }
.story-proof div:last-child { border: 0; }
.story-proof strong, .story-proof span { display: block; }
.story-proof strong { color: white; font-family: Georgia, serif; font-size: 25px; }
.story-proof span { color: rgba(255,255,255,.55); font-size: 11px; }
.story-visual { position: relative; z-index: 2; height: 180px; }
.visual-card { position: absolute; border: 1px solid rgba(255,255,255,.12); border-radius: 16px; background: rgba(255,255,255,.07); backdrop-filter: blur(10px); box-shadow: 0 20px 50px rgba(0,0,0,.15); }
.visual-card strong, .visual-card span { display: block; }
.visual-card-one { left: 0; bottom: 0; width: 290px; padding: 17px; transform: rotate(-3deg); }
.visual-card-two { left: 250px; bottom: 42px; width: 210px; padding: 18px; transform: rotate(4deg); }
.mini-label { margin-bottom: 5px; color: #8dd1ef; font-size: 9px; font-weight: 800; letter-spacing: 1px; text-transform: uppercase; }
.mini-board { display: grid; margin-top: 13px; grid-template-columns: repeat(5, 1fr); gap: 5px; }
.mini-board i { height: 18px; border-radius: 4px; background: rgba(255,255,255,.18); }
.mini-board i:nth-child(3n) { background: rgba(42,167,125,.55); }
.mini-success { width: max-content; margin-top: 15px; padding: 4px 7px; border-radius: 5px; color: #9dd9f2; background: rgba(69,168,216,.18); font-size: 9px; font-weight: 700; }

.login-panel { display: grid; min-height: 100vh; padding: 50px; place-items: center; background: #fbfcfa; }
.login-card { width: min(390px, 100%); }
.login-card h2 { margin: 14px 0 5px; font-size: 38px; }
.login-card > p { margin-bottom: 30px; }
.login-card label, .edit-panel label, .creator-form label { display: block; margin-bottom: 16px; color: var(--ink-soft); font-size: 11px; font-weight: 800; letter-spacing: .3px; }
.login-card input, .edit-panel input, .edit-panel textarea, .creator-form select, .bank-tools input, .bank-tools select, .upload-panel input, .upload-panel select, .upload-panel textarea, .feed-composer input, .feed-composer textarea, .guideline-editor input, .guideline-editor textarea, .guideline-tools input, .pd-form input, .pd-form select, .pd-form textarea {
  width: 100%;
  min-height: 47px;
  margin-top: 7px;
  padding: 0 13px;
  border: 1px solid var(--line);
  border-radius: 10px;
  color: var(--ink);
  background: white;
  transition: border .2s, box-shadow .2s;
}
.login-card input:focus, .edit-panel input:focus, .edit-panel textarea:focus, .creator-form select:focus, .bank-tools input:focus, .bank-tools select:focus, .upload-panel input:focus, .upload-panel select:focus, .upload-panel textarea:focus, .feed-composer input:focus, .feed-composer textarea:focus, .guideline-editor input:focus, .guideline-editor textarea:focus, .guideline-tools input:focus, .pd-form input:focus, .pd-form select:focus, .pd-form textarea:focus { border-color: var(--green); box-shadow: 0 0 0 3px rgba(42,167,125,.12); }
.login-card .button { width: 100%; margin-top: 7px; }
.prototype-note { display: block; margin-top: 14px; color: #91a0a8; text-align: center; font-size: 10px; }
.login-error { margin: -5px 0 10px; padding: 9px 11px; border: 1px solid #edc5c5; border-radius: 8px; color: #9f3838; background: #fff2f2; font-size: 10px; }
.login-mobile-brand { display: none; margin-bottom: 35px; }

.app-shell { min-height: 100vh; }

.sidebar {
  position: fixed;
  z-index: 20;
  display: flex;
  width: var(--sidebar);
  height: 100vh;
  padding: 24px 18px 18px;
  flex-direction: column;
  border-right: 1px solid var(--line-soft);
  background: #fbfcfa;
}

.sidebar .brand { padding: 0 7px; }
.main-nav { display: flex; margin-top: 38px; flex-direction: column; gap: 5px; }
.nav-label { margin: 0 10px 8px; color: #9aa8ae; font-size: 9px; font-weight: 800; letter-spacing: 1.3px; text-transform: uppercase; }
.nav-item {
  display: flex;
  width: 100%;
  min-height: 44px;
  padding: 0 10px;
  align-items: center;
  gap: 10px;
  border: 0;
  border-radius: 10px;
  color: var(--ink-soft);
  background: transparent;
  text-align: left;
  font-size: 12px;
  font-weight: 700;
}
.nav-item:hover { color: var(--ink); background: #f0f5f2; }
.nav-item.active { color: var(--green-dark); background: linear-gradient(90deg, var(--green-soft), #f1f8fc); }
.nav-icon { display: grid; width: 23px; height: 23px; border: 1px solid #cfdcdf; border-radius: 7px; place-items: center; font-size: 9px; }
.nav-item.active .nav-icon { color: white; border-color: var(--green); background: var(--green); }
.nav-badge { margin-left: auto; padding: 2px 5px; border-radius: 4px; color: var(--green-dark); background: white; font-size: 7px; }
.sidebar-tip { margin-top: auto; padding: 14px; border: 1px solid #d9e8e3; border-radius: 13px; background: #f4faf7; }
.sidebar-tip strong { display: block; margin: 7px 0 2px; font-size: 11px; }
.sidebar-tip p { margin: 0; font-size: 9px; line-height: 1.45; }
.tip-icon { display: grid; width: 20px; height: 20px; border-radius: 50%; place-items: center; color: white; background: var(--green); font-family: Georgia, serif; font-size: 11px; font-weight: 700; }
.teacher-profile { display: flex; width: 100%; margin-top: 13px; padding: 10px 7px; align-items: center; gap: 9px; border: 0; border-top: 1px solid var(--line-soft); color: var(--ink); background: transparent; text-align: left; }
.teacher-profile strong, .teacher-profile small { display: block; }
.teacher-profile strong { font-size: 11px; }
.teacher-profile small { color: var(--muted); font-size: 9px; }
.avatar { display: grid; width: 30px; height: 30px; border-radius: 9px; place-items: center; color: var(--navy); background: var(--peach-soft); font-size: 9px; font-weight: 800; }
.profile-more { margin-left: auto; color: var(--muted); }

.main-content { min-width: 0; margin-left: var(--sidebar); }
.topbar {
  position: sticky;
  z-index: 10;
  top: 0;
  display: flex;
  height: 72px;
  padding: 0 clamp(20px, 3.5vw, 56px);
  align-items: center;
  justify-content: space-between;
  border-bottom: 1px solid var(--line-soft);
  background: rgba(255,255,255,.9);
  backdrop-filter: blur(12px);
}
.page-location span, .page-location strong { display: block; }
.page-location span { color: var(--muted); font-size: 8px; font-weight: 800; letter-spacing: 1px; text-transform: uppercase; }
.page-location strong { margin-top: -1px; font-family: Georgia, serif; font-size: 18px; }
.topbar-actions { display: flex; align-items: center; gap: 9px; }
.global-search { position: relative; display: flex; width: min(280px, 25vw); height: 39px; align-items: center; }
.global-search > span { position: absolute; left: 12px; color: var(--muted); font-weight: 800; }
.global-search input { width: 100%; height: 100%; padding: 0 45px 0 31px; border: 1px solid var(--line); border-radius: 11px; background: #f9fbfa; font-size: 11px; }
.global-search kbd { position: absolute; right: 9px; padding: 2px 5px; border: 1px solid var(--line); border-radius: 5px; color: var(--muted); background: white; font-family: inherit; font-size: 7px; }
.notification-dot { position: absolute; top: 7px; right: 7px; width: 5px; height: 5px; border-radius: 50%; background: var(--peach); }
.notification-wrap { position: relative; }
.notification-panel {
  position: absolute;
  z-index: 40;
  top: calc(100% + 10px);
  right: 0;
  width: 280px;
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: white;
  box-shadow: var(--shadow-lg);
}
.notification-panel::before {
  position: absolute;
  top: -6px;
  right: 15px;
  width: 10px;
  height: 10px;
  border-top: 1px solid var(--line);
  border-left: 1px solid var(--line);
  background: white;
  content: "";
  transform: rotate(45deg);
}
.notification-heading { margin-bottom: 10px; }
.notification-heading strong { display: block; margin-top: 2px; color: var(--ink); font-size: 14px; }
.notification-item {
  display: grid;
  padding: 10px 0;
  grid-template-columns: 28px 1fr;
  gap: 9px;
  border-top: 1px solid var(--line-soft);
}
.notification-item:first-child { border-top: 0; }
.notification-item b {
  display: grid;
  width: 26px;
  height: 26px;
  border-radius: 8px;
  place-items: center;
  color: var(--green-dark);
  background: var(--green-soft);
  font-size: 8px;
}
.notification-item strong, .notification-item span, .notification-item small { display: block; }
.notification-item strong { color: var(--ink); font-size: 10px; }
.notification-item span { color: var(--muted); font-size: 8px; line-height: 1.4; }
.notification-item small { margin-top: 4px; color: var(--green-dark); font-size: 7px; font-weight: 900; letter-spacing: .4px; text-transform: uppercase; }
.mobile-menu-button { display: none; width: auto; padding: 0 10px; }

.screen-wrap { width: min(1460px, 100%); margin: 0 auto; padding: 42px clamp(20px, 3.5vw, 56px) 70px; }
.screen { display: none; animation: fadeUp .35s ease both; }
.screen.active { display: block; }
@keyframes fadeUp { from { opacity: 0; transform: translateY(5px); } to { opacity: 1; transform: translateY(0); } }

.welcome-row { display: flex; align-items: flex-end; justify-content: space-between; }
.welcome-row h1 { margin-top: 8px; }
.welcome-row p { margin-bottom: 0; }
.week-snapshot { min-width: 225px; padding: 14px 17px; border: 1px solid var(--line); border-radius: 13px; background: white; box-shadow: var(--shadow-sm); }
.week-snapshot span, .week-snapshot strong { display: block; }
.week-snapshot span { color: var(--muted); font-size: 9px; font-weight: 800; letter-spacing: .8px; text-transform: uppercase; }
.week-snapshot strong { margin: 3px 0 9px; font-size: 11px; }
.progress-track { height: 4px; border-radius: 4px; background: #e8eeee; overflow: hidden; }
.progress-track i { display: block; width: 72%; height: 100%; border-radius: inherit; background: var(--green); }

.action-grid { display: grid; margin: 35px 0 45px; grid-template-columns: 1.15fr .85fr; gap: 19px; }
.action-card { position: relative; min-height: 255px; padding: 30px; overflow: hidden; border: 0; border-radius: var(--radius); color: white; text-align: left; box-shadow: var(--shadow-sm); transition: transform .25s, box-shadow .25s; }
.action-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-lg); }
.create-card { background: linear-gradient(140deg, var(--navy-deep), #176da6); }
.bank-card { color: var(--ink); background: linear-gradient(140deg, #dff2fb, #f1f9fd); }
.action-kicker { display: block; margin-bottom: 50px; color: #9ad9f2; font-size: 9px; font-weight: 800; letter-spacing: 1.2px; text-transform: uppercase; }
.bank-card .action-kicker { color: #277daf; }
.action-card strong, .action-card p, .action-card .card-link { position: relative; z-index: 2; display: block; max-width: 390px; }
.action-card strong { font-family: Georgia, serif; font-size: 26px; }
.action-card p { max-width: 420px; margin: 7px 0 20px; color: rgba(255,255,255,.62); font-size: 12px; }
.bank-card p { color: #53778c; }
.card-link { width: max-content; color: white; font-size: 11px; font-weight: 800; }
.bank-card .card-link { color: #176da6; }
.card-link b { margin-left: 5px; }
.action-orb { position: absolute; top: -45px; right: -20px; width: 190px; height: 190px; border: 1px solid rgba(255,255,255,.08); border-radius: 50%; box-shadow: 0 0 0 38px rgba(255,255,255,.025), 0 0 0 76px rgba(255,255,255,.018); }
.action-orb i { position: absolute; width: 11px; height: 11px; border-radius: 50%; background: var(--green); box-shadow: 0 0 18px #70e2be; }
.action-orb i:nth-child(1) { left: 20px; bottom: 38px; }
.action-orb i:nth-child(2) { right: 27px; bottom: 8px; background: var(--peach); }
.action-orb i:nth-child(3) { left: 80px; bottom: 5px; background: var(--yellow); }
.stack-visual { position: absolute; top: 28px; right: 33px; width: 135px; height: 96px; }
.stack-visual i { position: absolute; width: 96px; height: 68px; border: 1px solid rgba(23,109,166,.15); border-radius: 11px; background: rgba(255,255,255,.65); box-shadow: 0 8px 20px rgba(23, 109, 166, .08); }
.stack-visual i:nth-child(1) { top: 15px; left: 0; transform: rotate(-11deg); }
.stack-visual i:nth-child(2) { top: 7px; left: 18px; transform: rotate(2deg); }
.stack-visual i:nth-child(3) { top: 0; left: 35px; transform: rotate(11deg); background: repeating-linear-gradient(0deg, #fff, #fff 11px, #d6edf8 12px); }

.section-heading { display: flex; margin-bottom: 16px; align-items: flex-end; justify-content: space-between; }
.section-heading h2 { margin: 4px 0 0; }
.section-heading.small { align-items: flex-start; }
.resource-list { display: flex; flex-direction: column; gap: 10px; }
.resource-row {
  display: grid;
  min-height: 76px;
  padding: 12px 14px;
  align-items: center;
  grid-template-columns: 48px minmax(190px, 1.6fr) minmax(150px, .9fr) minmax(140px, .8fr) auto;
  gap: 13px;
  border: 1px solid var(--line-soft);
  border-radius: 13px;
  background: white;
  transition: border .2s, transform .2s, box-shadow .2s;
}
.resource-row:hover { border-color: #c9d7da; transform: translateY(-1px); box-shadow: var(--shadow-sm); }
.resource-thumb, .resource-card-thumb { display: grid; border-radius: 10px; place-items: center; color: var(--navy); background: var(--green-soft); font-size: 9px; font-weight: 900; }
.resource-thumb { width: 48px; height: 48px; }
.resource-thumb.mingle { background: var(--peach-soft); }
.resource-thumb.role, .resource-thumb.thinking { background: var(--purple-soft); }
.resource-thumb.cards, .resource-thumb.quote { background: #e6f3fb; }
.resource-thumb.jigsaw { background: #fff1d9; }
.resource-thumb.gap { background: #f2fbff; }
.resource-thumb.gallery { background: #eef7f2; }
.resource-thumb.upload { background: #dff2fb; }
.resource-row-title strong, .resource-row-title span, .resource-meta strong, .resource-meta span { display: block; }
.resource-row-title strong { font-size: 12px; }
.resource-row-title span, .resource-meta span { color: var(--muted); font-size: 9px; }
.resource-meta strong { font-size: 10px; }
.resource-row .button { min-height: 34px; padding: 0 12px; font-size: 9px; }
.status-pill { display: inline-flex; width: max-content; padding: 4px 7px; border-radius: 20px; color: #805538; background: var(--peach-soft); font-size: 8px; font-weight: 800; }
.status-pill.green { color: var(--green-dark); background: var(--green-soft); }
.stars { color: var(--yellow); letter-spacing: 1px; white-space: nowrap; }

.dashboard-lower { display: grid; margin-top: 34px; grid-template-columns: 1.3fr .7fr; gap: 18px; }
.insight-card, .quote-card { padding: 23px; border: 1px solid var(--line-soft); border-radius: var(--radius); background: white; }
.topic-bars { display: flex; flex-direction: column; gap: 14px; margin-top: 22px; }
.topic-bars div { display: grid; align-items: center; grid-template-columns: 180px 1fr 24px; gap: 12px; color: var(--ink-soft); font-size: 10px; }
.topic-bars i { position: relative; height: 5px; border-radius: 5px; background: #edf1f1; }
.topic-bars i::after { display: block; width: var(--bar); height: 100%; border-radius: inherit; background: var(--green); content: ""; }
.topic-bars b { color: var(--muted); font-size: 9px; }
.quote-card { position: relative; display: flex; min-height: 210px; padding: 27px; flex-direction: column; justify-content: space-between; overflow: hidden; color: white; background: linear-gradient(145deg, var(--navy), var(--navy-deep)); }
.quote-card::after { position: absolute; right: -45px; bottom: -55px; width: 190px; height: 190px; background: url("assets/alc-logo.png") center / contain no-repeat; content: ""; opacity: .08; }
.quote-card p { margin: 0; color: white; font-family: Georgia, serif; font-size: 22px; line-height: 1.25; }
.quote-card > span:last-child { color: rgba(255,255,255,.45); font-size: 9px; font-weight: 800; letter-spacing: .8px; text-transform: uppercase; }
.quote-mark { color: var(--green); font-family: Georgia, serif; font-size: 42px; line-height: .7; }

.page-heading { display: flex; margin-bottom: 30px; align-items: flex-end; justify-content: space-between; gap: 25px; }
.page-heading h1 { margin: 7px 0 7px; }
.page-heading p { margin: 0; }
.wizard-progress { display: flex; align-items: center; gap: 7px; }
.wizard-progress span { display: flex; align-items: center; gap: 5px; color: var(--muted); font-size: 9px; font-weight: 800; }
.wizard-progress span.active { color: var(--green-dark); }
.wizard-progress b { display: grid; width: 21px; height: 21px; border: 1px solid var(--line); border-radius: 50%; place-items: center; font-size: 8px; }
.wizard-progress .active b { color: white; border-color: var(--green); background: var(--green); }
.wizard-progress i { width: 22px; height: 1px; background: var(--line); }

.creator-layout { display: grid; align-items: start; grid-template-columns: minmax(0, 1fr) 300px; gap: 20px; }
.creator-form { display: flex; flex-direction: column; gap: 14px; }
.form-section { padding: 24px; border: 1px solid var(--line-soft); border-radius: var(--radius); background: white; }
.form-section-title { display: flex; margin-bottom: 20px; align-items: flex-start; gap: 12px; }
.form-section-title > span { display: grid; width: 27px; height: 27px; flex: 0 0 auto; border-radius: 8px; place-items: center; color: var(--green-dark); background: var(--green-soft); font-size: 8px; font-weight: 900; }
.form-section-title h2 { margin: 0; font-family: inherit; font-size: 15px; }
.form-section-title p { margin: 2px 0 0; font-size: 10px; }
.field-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.field-grid.three-fields { grid-template-columns: repeat(3, 1fr); }
.field-grid label { margin: 0; }
.creator-form select { cursor: pointer; }
.curriculum-note { display: flex; margin-top: 4px; padding: 11px 12px; align-items: center; gap: 8px; border-radius: 9px; color: var(--ink-soft); background: #f7faf8; font-size: 9px; }
.curriculum-note strong { color: var(--green-dark); }
.curriculum-note span { padding: 2px 5px; border-radius: 4px; color: var(--green-dark); background: var(--green-soft); font-weight: 800; }
.type-options { display: grid; grid-template-columns: repeat(auto-fit, minmax(155px, 1fr)); gap: 11px; }
.type-option { position: relative; min-height: 145px; margin: 0 !important; padding: 14px; border: 1px solid var(--line); border-radius: 13px; cursor: pointer; transition: border .2s, box-shadow .2s, transform .2s; }
.type-option:hover { transform: translateY(-2px); box-shadow: var(--shadow-sm); }
.type-option.selected { border-color: var(--green); box-shadow: 0 0 0 2px rgba(42,167,125,.1); }
.type-option input { position: absolute; opacity: 0; }
.type-option strong, .type-option small { display: block; }
.type-option strong { margin-top: 10px; color: var(--ink); font-size: 11px; }
.type-option small { margin-top: 2px; color: var(--muted); font-size: 8px; line-height: 1.3; }
.check-mark { position: absolute; display: none; top: 9px; right: 9px; width: 17px; height: 17px; border-radius: 50%; place-items: center; color: white; background: var(--green); font-size: 8px; }
.type-option.selected .check-mark { display: grid; }
.type-illustration { display: grid; width: 100%; height: 55px; padding: 8px; border-radius: 8px; background: #f5f8f6; gap: 3px; }
.board-illustration { grid-template-columns: repeat(4, 1fr); }
.board-illustration i { border-radius: 3px; background: #d8e8e1; }
.board-illustration i:nth-child(2), .board-illustration i:nth-child(4) { background: var(--peach-soft); }
.mingle-illustration { grid-template-rows: repeat(3, 1fr); }
.mingle-illustration i { border-radius: 3px; background: repeating-linear-gradient(90deg, #d8e8e1, #d8e8e1 45%, white 45%, white 48%); }
.role-illustration { grid-template-columns: 1fr 1fr; }
.role-illustration i { border: 1px solid #dfd9ee; border-radius: 5px; background: var(--purple-soft); }
.cards-illustration, .quote-illustration { grid-template-columns: repeat(3, 1fr); }
.cards-illustration i, .quote-illustration i { border-radius: 6px; background: #e6f3fb; box-shadow: inset 0 -12px 0 rgba(57, 161, 213, .16); }
.jigsaw-illustration { grid-template-columns: 1fr 1fr; }
.jigsaw-illustration i { border-radius: 2px 8px 2px 8px; background: #fff1d9; }
.gap-illustration { grid-template-columns: 1fr 1fr; }
.gap-illustration i { border: 1px dashed #8fb9c9; border-radius: 7px; background: #f2fbff; }
.thinking-illustration { grid-template-columns: repeat(3, 1fr); }
.thinking-illustration i { border-radius: 50%; background: #eee7fb; }
.thinking-illustration i:nth-child(2) { border-radius: 6px; background: #d9f1e7; }
.gallery-illustration { grid-template-columns: repeat(3, 1fr); }
.gallery-illustration i { border: 5px solid white; border-radius: 6px; background: linear-gradient(135deg, #d9f1e7, #dceffc); box-shadow: 0 3px 10px rgba(27,53,63,.13); }
.button-generate { width: 100%; justify-content: space-between; padding: 0 22px; color: white; background: var(--navy); box-shadow: var(--shadow-sm); }
.button-generate:hover { background: var(--navy-deep); box-shadow: var(--shadow-lg); }
.button-generate b { font-size: 17px; }

.creation-summary { position: sticky; top: 93px; padding: 18px; border: 1px solid var(--line-soft); border-radius: var(--radius); background: white; box-shadow: var(--shadow-sm); }
.summary-label { display: block; margin-bottom: 13px; color: var(--muted); font-size: 8px; font-weight: 800; letter-spacing: 1px; text-transform: uppercase; }
.summary-template { display: flex; height: 130px; padding: 13px; flex-direction: column; justify-content: space-between; border-radius: 12px; color: white; background: var(--navy); }
.summary-template > span { font-family: Georgia, serif; font-size: 16px; }
.summary-board { display: grid; grid-template-columns: repeat(5, 1fr); gap: 4px; }
.summary-board i { height: 19px; border-radius: 3px; background: rgba(255,255,255,.13); }
.summary-board i:nth-child(3n) { background: rgba(42,167,125,.65); }
.creation-summary h3 { margin: 16px 0 11px; font-family: Georgia, serif; font-size: 20px; }
.creation-summary dl { margin: 0; }
.creation-summary dl div { display: flex; padding: 8px 0; justify-content: space-between; gap: 12px; border-top: 1px solid var(--line-soft); }
.creation-summary dt { color: var(--muted); font-size: 8px; font-weight: 800; text-transform: uppercase; }
.creation-summary dd { margin: 0; color: var(--ink); text-align: right; font-size: 9px; font-weight: 700; }
.ai-recipe-note { display: flex; margin-top: 13px; padding: 11px; align-items: flex-start; gap: 8px; border-radius: 9px; background: var(--green-soft); }
.ai-recipe-note > span { display: grid; width: 24px; height: 24px; flex: 0 0 auto; border-radius: 7px; place-items: center; color: white; background: var(--green); font-size: 7px; font-weight: 900; }
.ai-recipe-note p { margin: 0; font-size: 8px; line-height: 1.45; }
.ai-recipe-note strong { display: block; color: var(--green-dark); }

.preview-heading { align-items: flex-end; }
.preview-actions { display: flex; justify-content: flex-end; gap: 7px; flex-wrap: wrap; }
.editor-layout { display: grid; align-items: start; grid-template-columns: minmax(0, 1fr) 340px; gap: 20px; }
.editor-layout.editor-closed { grid-template-columns: minmax(0, 1fr); }
.paper-stage { min-width: 0; padding: 12px; border: 1px solid var(--line); border-radius: var(--radius); background: #edf1ee; }
.paper-toolbar { display: flex; padding: 2px 5px 12px; align-items: center; justify-content: space-between; color: var(--muted); font-size: 9px; font-weight: 700; }
.status-dot { display: inline-block; width: 6px; height: 6px; margin-right: 4px; border-radius: 50%; background: var(--green); box-shadow: 0 0 0 3px rgba(42,167,125,.13); }
.activity-paper { min-height: 790px; padding: clamp(25px, 4vw, 55px); color: #193343; background: white; box-shadow: 0 8px 24px rgba(36,64,75,.12); }
.paper-header { display: flex; padding-bottom: 18px; align-items: flex-start; justify-content: space-between; border-bottom: 2px solid var(--navy); gap: 20px; }
.paper-header h2 { margin: 4px 0 4px; color: var(--navy); font-size: 29px; }
.paper-header p { margin: 0; font-size: 10px; }
.paper-logo { display: grid; width: 56px; height: 56px; padding: 5px; flex: 0 0 auto; border: 1px solid var(--line); border-radius: 14px; place-items: center; background: white; }
.paper-logo img { display: block; width: 100%; height: 100%; object-fit: contain; }
.paper-meta { display: flex; margin: 13px 0 20px; gap: 7px; flex-wrap: wrap; }
.paper-meta span { padding: 5px 8px; border-radius: 5px; color: var(--ink-soft); background: #f1f5f3; font-size: 8px; font-weight: 800; }
.paper-instructions { margin-bottom: 20px; padding: 11px 13px; border-left: 3px solid var(--green); color: var(--ink-soft); background: var(--green-soft); font-size: 9px; }
.paper-instructions strong { color: var(--green-dark); }
.paper-instructions span, .paper-instructions em, .paper-instructions small { display: block; margin-top: 5px; font-style: normal; }
.paper-instructions span { color: var(--ink); font-weight: 800; }
.paper-instructions em { color: var(--muted); }
.paper-instructions small { color: var(--green-dark); font-size: 8px; font-weight: 800; }
.upload-preview-card { display: grid; min-height: 280px; margin-top: 28px; padding: clamp(22px, 4vw, 42px); align-items: center; grid-template-columns: 118px 1fr; gap: 24px; border: 1px solid #c9e0ea; border-radius: 20px; background: linear-gradient(135deg, #f7fcff, #eef8fc); }
.upload-file-icon { display: grid; width: 105px; height: 128px; border: 2px solid #c5ddea; border-radius: 18px; place-items: center; color: var(--navy); background: white; font-family: Georgia, serif; font-size: 27px; font-weight: 900; box-shadow: 0 10px 22px rgba(25, 80, 118, .08); }
.upload-preview-card h3 { margin: 5px 0 9px; color: var(--navy); font-family: Georgia, serif; font-size: 25px; }
.upload-preview-card p { margin: 0 0 10px; color: var(--ink-soft); font-size: 11px; line-height: 1.6; }
.upload-preview-card small { display: block; max-width: 620px; color: var(--muted); font-size: 9px; line-height: 1.6; }
.paper-link-button { display: inline-flex; min-height: 34px; margin-top: 18px; padding: 0 14px; align-items: center; border-radius: 10px; color: white; background: var(--navy); font-size: 9px; font-weight: 900; text-decoration: none; }
.board-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 7px; }
.board-cell { position: relative; display: flex; min-height: 112px; padding: 13px 10px 9px; align-items: center; justify-content: center; border: 1px solid #d5e1e0; border-radius: 8px; color: var(--ink); background: #f8faf8; text-align: center; font-size: 9px; font-weight: 700; }
.board-cell:nth-child(3n) { border-color: #f2d4c2; background: var(--peach-soft); }
.board-cell:nth-child(4n) { border-color: #c8e5db; background: var(--green-soft); }
.board-cell b { position: absolute; top: 6px; left: 7px; color: var(--muted); font-size: 7px; }
.mingle-table { width: 100%; border-collapse: collapse; font-size: 9px; }
.mingle-table th { padding: 10px; color: white; background: var(--navy); text-align: left; }
.mingle-table td { height: 48px; padding: 8px 10px; border: 1px solid #d9e3e3; }
.mingle-table td:first-child { width: 28px; color: var(--green-dark); font-weight: 900; }
.mingle-table td:last-child { width: 30%; }
.role-card-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.role-card-print { min-height: 170px; padding: 17px; border: 1px dashed #aababc; border-radius: 10px; background: #fbfcfb; }
.role-card-print:nth-child(3n) { background: var(--purple-soft); }
.role-card-print span { color: var(--purple); font-size: 7px; font-weight: 900; letter-spacing: 1px; text-transform: uppercase; }
.role-card-print h3 { margin: 8px 0; color: var(--navy); font-family: Georgia, serif; }
.role-card-print p { font-size: 9px; line-height: 1.55; }
.prompt-card-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 11px; }
.prompt-card { min-height: 155px; padding: 15px; border: 1px solid #d7e6ec; border-radius: 13px; background: #f8fcff; }
.prompt-card:nth-child(3n) { border-color: #c6e4d8; background: var(--green-soft); }
.prompt-card:nth-child(4n) { border-color: #efd7c7; background: var(--peach-soft); }
.prompt-card span, .jigsaw-card span, .thinking-card span, .quote-card-print span, .gallery-card-print span { color: var(--muted); font-size: 7px; font-weight: 900; letter-spacing: 1px; text-transform: uppercase; }
.prompt-card h3, .jigsaw-card h3, .thinking-card h3, .quote-card-print h3, .gallery-card-print h3 { margin: 8px 0; color: var(--navy); font-family: Georgia, serif; font-size: 14px; }
.prompt-card p, .jigsaw-card p, .thinking-card p, .quote-card-print p, .gallery-card-print p { margin: 0; font-size: 9px; line-height: 1.55; }
.template-strip { display: flex; margin-bottom: 14px; padding: 11px 13px; gap: 8px; border-radius: 12px; background: #f4f8f9; color: var(--ink-soft); font-size: 9px; line-height: 1.5; }
.template-strip strong { color: var(--navy); }
.jigsaw-grid, .thinking-grid, .quote-grid, .gallery-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 12px; }
.jigsaw-card, .thinking-card, .quote-card-print, .gallery-card-print { min-height: 155px; padding: 16px; border: 1px solid #ddd9eb; border-radius: 13px; background: #fcfbff; }
.jigsaw-card:nth-child(2n) { border-color: #efd8aa; background: #fffaf0; }
.thinking-card { background: #fbf8ff; }
.thinking-card:nth-child(2n) { border-color: #cfe9dc; background: #f4fbf7; }
.quote-card-print { border-color: #d7e6ec; background: #f8fcff; }
.quote-card-print h3 { font-size: 17px; line-height: 1.35; }
.gallery-card-print { border-color: #dce8df; background: #fbfcfb; }
.gap-handouts { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.gap-handout { padding: 16px; border: 1px dashed #a5c4cc; border-radius: 14px; background: #f8fcff; }
.gap-handout h3 { margin: 0 0 9px; color: var(--navy); font-family: Georgia, serif; }
.gap-handout ul { margin: 0; padding-left: 17px; }
.gap-handout li { margin-bottom: 8px; font-size: 9px; line-height: 1.5; }
.paper-footer { display: flex; margin-top: 25px; padding-top: 9px; justify-content: space-between; border-top: 1px solid #e2e9e8; color: #8b999e; font-size: 7px; }
.edit-panel { position: sticky; top: 92px; max-height: calc(100vh - 110px); padding: 20px; overflow: auto; border: 1px solid var(--line-soft); border-radius: var(--radius); background: white; box-shadow: var(--shadow-sm); }
.panel-heading { margin-bottom: 17px; }
.panel-heading h2 { margin: 4px 0; font-size: 21px; }
.panel-heading p { margin: 0; font-size: 9px; }
.edit-panel textarea { min-height: 73px; padding: 10px 12px; resize: vertical; font-size: 10px; line-height: 1.45; }
.fine-tune-mode-switch { display: grid; margin-bottom: 16px; padding: 4px; grid-template-columns: 1fr 1fr; gap: 4px; border: 1px solid var(--line-soft); border-radius: 13px; background: var(--green-soft); }
.fine-tune-mode-switch button { min-height: 36px; border: 0; border-radius: 10px; color: var(--ink-soft); background: transparent; font-size: 9px; font-weight: 900; cursor: pointer; }
.fine-tune-mode-switch button.active { color: white; background: var(--green); box-shadow: var(--shadow-sm); }
.manual-fine-tune-box, .ai-fine-tune-box { margin-bottom: 16px; }
.ai-fine-tune-box { padding: 13px; border: 1px solid var(--line-soft); border-radius: 13px; background: var(--green-soft); }
.ai-fine-tune-box label { margin-bottom: 9px; }
.ai-fine-tune-box textarea { min-height: 96px; background: white; }
.ai-fine-tune-box p { margin: 8px 0 0; font-size: 8px; line-height: 1.45; }
.fine-tune-hint { margin: -4px 0 0; color: var(--muted); font-size: 8px; line-height: 1.45; }
.fine-tune-submit { width: 100%; min-height: 42px; margin-top: 16px; font-size: 9px; }
.editable-item-label { display: flex; margin-bottom: 4px; justify-content: space-between; }
.editable-item-label b { color: var(--muted); font-size: 8px; }
.adapt-box { display: grid; margin-top: 17px; padding: 11px; align-items: center; grid-template-columns: 27px 1fr; gap: 7px; border-radius: 10px; background: var(--peach-soft); }
.adapt-icon { display: grid; width: 27px; height: 27px; border-radius: 8px; place-items: center; color: white; background: var(--peach); font-size: 8px; font-weight: 900; }
.adapt-box strong { display: block; font-size: 9px; }
.adapt-box p { margin: 1px 0 0; font-size: 7px; }
.adapt-box button { grid-column: 2; width: max-content; color: #a65e39; font-size: 8px; }

.bank-heading { align-items: center; }
.bank-tools { display: grid; margin-bottom: 15px; padding: 13px; align-items: end; grid-template-columns: minmax(240px, 1fr) 150px 180px auto auto; gap: 9px; border: 1px solid var(--line-soft); border-radius: 14px; background: white; }
.bank-tools label { color: var(--muted); font-size: 8px; font-weight: 800; letter-spacing: .5px; text-transform: uppercase; }
.bank-tools input, .bank-tools select { min-height: 40px; margin-top: 5px; font-size: 10px; text-transform: none; }
.bank-search { position: relative; }
.bank-search span { position: absolute; z-index: 2; left: 13px; bottom: 12px; color: var(--muted); }
.bank-search input { padding-left: 30px; }
.bank-tools .button { min-height: 40px; font-size: 9px; }
.bank-summary { display: flex; margin: 15px 1px; justify-content: space-between; color: var(--muted); font-size: 9px; }
.bank-summary strong { color: var(--ink); }
.resource-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
.bank-favorites-toggle.active { color: var(--green-dark); border-color: #b8ddeb; background: var(--green-soft); }
.resource-card { display: flex; min-height: 275px; padding: 15px; flex-direction: column; border: 1px solid var(--line-soft); border-radius: 15px; background: white; transition: transform .2s, box-shadow .2s, border .2s; }
.resource-card:hover { transform: translateY(-2px); border-color: #cddadc; box-shadow: var(--shadow-sm); }
.resource-card-thumb { position: relative; display: block; height: 105px; padding: 13px; overflow: hidden; text-align: left; }
.resource-card-thumb.board { background: var(--green-soft); }
.resource-card-thumb.mingle { background: var(--peach-soft); }
.resource-card-thumb.role { background: var(--purple-soft); }
.resource-card-thumb.cards, .resource-card-thumb.quote { background: #e6f3fb; }
.resource-card-thumb.jigsaw { background: #fff1d9; }
.resource-card-thumb.gap { background: #f2fbff; }
.resource-card-thumb.thinking { background: #eee7fb; }
.resource-card-thumb.gallery { background: #eef7f2; }
.resource-card-thumb.upload { background: #dff2fb; }
.resource-card-thumb > span { position: relative; z-index: 2; color: var(--ink-soft); font-size: 8px; font-weight: 900; letter-spacing: .8px; text-transform: uppercase; }
.thumb-board { position: absolute; right: 10px; bottom: 10px; display: grid; width: 125px; grid-template-columns: repeat(4, 1fr); gap: 4px; transform: rotate(-4deg); }
.thumb-board i { height: 21px; border-radius: 4px; background: rgba(255,255,255,.7); }
.thumb-board i:nth-child(3n) { background: rgba(42,167,125,.35); }
.resource-card h3 { margin: 14px 0 4px; font-family: Georgia, serif; font-size: 18px; }
.resource-card > p { margin-bottom: 11px; font-size: 9px; }
.tag-row { display: flex; gap: 5px; flex-wrap: wrap; }
.tag-row span { padding: 3px 6px; border-radius: 4px; color: var(--muted); background: #f2f5f4; font-size: 7px; font-weight: 800; }
.card-footer { display: flex; margin-top: auto; padding-top: 12px; align-items: center; justify-content: space-between; border-top: 1px solid var(--line-soft); }
.creator-line { display: flex; align-items: center; gap: 6px; color: var(--muted); font-size: 8px; }
.creator-dot { display: grid; width: 20px; height: 20px; border-radius: 6px; place-items: center; color: var(--navy); background: var(--peach-soft); font-size: 6px; font-weight: 900; }
.card-open { padding: 0; border: 0; color: var(--green-dark); background: transparent; font-size: 8px; font-weight: 900; }
.rating-row { display: flex; margin-top: 10px; align-items: center; gap: 2px; }
.rating-star { padding: 0; border: 0; color: #d9e0df; background: transparent; font-size: 15px; line-height: 1; }
.rating-star.filled { color: var(--yellow); }
.rating-row span { margin-left: 4px; color: var(--muted); font-size: 7px; }
.bank-card-actions { display: grid; margin-top: 11px; grid-template-columns: 1fr 1fr; gap: 7px; }
.bank-card-actions button { min-height: 31px; padding: 0 9px; border: 1px solid var(--line-soft); border-radius: 10px; color: var(--ink-soft); background: #fbfdfe; font-size: 8px; font-weight: 900; text-align: left; }
.bank-card-actions button:last-child { grid-column: 1 / -1; text-align: center; }
.bank-card-actions button.active { color: var(--green-dark); border-color: #b8ddeb; background: var(--green-soft); }
.bank-card-actions span { display: inline-block; width: 13px; color: var(--peach); font-size: 10px; text-align: center; }
.bank-card-actions b { float: right; color: inherit; font-size: 8px; }
.empty-state { padding: 60px 20px; border: 1px dashed #cedbdd; border-radius: 15px; background: white; text-align: center; }
.empty-state > span { display: grid; width: 38px; height: 38px; margin: 0 auto 13px; border-radius: 50%; place-items: center; color: var(--green-dark); background: var(--green-soft); font-family: Georgia, serif; font-size: 18px; }
.empty-state p { font-size: 10px; }

.saved-stats { display: grid; margin-bottom: 23px; grid-template-columns: repeat(3, 1fr); gap: 12px; }
.saved-stats div { padding: 17px; border: 1px solid var(--line-soft); border-radius: 13px; background: white; }
.saved-stats span, .saved-stats strong { display: block; }
.saved-stats span { color: var(--muted); font-size: 8px; font-weight: 800; letter-spacing: .6px; text-transform: uppercase; }
.saved-stats strong { margin-top: 3px; font-family: Georgia, serif; font-size: 27px; }

.feed-heading { align-items: center; }
.feed-composer, .upload-panel {
  margin-bottom: 20px;
  padding: 19px;
  border: 1px solid var(--line-soft);
  border-radius: var(--radius);
  background: white;
  box-shadow: var(--shadow-sm);
}
.feed-composer {
  display: grid;
  grid-template-columns: minmax(220px, .75fr) minmax(180px, .85fr) minmax(260px, 1.2fr) minmax(150px, .7fr) auto;
  align-items: end;
  gap: 12px;
}
.feed-composer h2, .upload-panel h2 { margin: 4px 0 4px; font-size: 22px; }
.feed-composer p, .upload-panel p { margin-bottom: 0; font-size: 9px; }
.feed-composer label, .upload-panel label { color: var(--ink-soft); font-size: 8px; font-weight: 800; }
.feed-composer input, .feed-composer textarea, .upload-panel input, .upload-panel select, .upload-panel textarea { margin-top: 5px; font-size: 9px; }
.feed-composer textarea, .upload-panel textarea { min-height: 76px; padding: 10px; resize: vertical; line-height: 1.45; }
.feed-audience-field { display: flex; min-height: 76px; margin: 0; padding: 10px; flex-direction: column; justify-content: center; gap: 6px; border: 1px solid var(--line); border-radius: 11px; color: var(--ink-soft); background: #fbfdfe; }
.feed-audience-field legend { padding: 0 4px; color: var(--muted); font-size: 8px; font-weight: 900; letter-spacing: .5px; text-transform: uppercase; }
.feed-audience-field label { display: flex; margin: 0; align-items: center; gap: 7px; color: var(--ink-soft); font-size: 8px; font-weight: 900; }
.feed-audience-field input { width: auto; min-height: auto; margin: 0; accent-color: var(--green); }
.feed-list { display: flex; flex-direction: column; gap: 13px; }
.feed-post {
  display: grid;
  grid-template-columns: 42px 1fr;
  gap: 12px;
  padding: 18px;
  border: 1px solid var(--line-soft);
  border-radius: 16px;
  background: white;
  box-shadow: var(--shadow-sm);
}
.feed-post-avatar { display: grid; width: 42px; height: 42px; border-radius: 13px; place-items: center; color: var(--navy); background: var(--green-soft); font-size: 9px; font-weight: 900; }
.feed-post-header { display: flex; align-items: flex-start; justify-content: space-between; gap: 14px; }
.feed-post-header strong, .feed-post-header span { display: block; }
.feed-post-header strong { color: var(--ink); font-size: 12px; }
.feed-post-header span, .feed-post time { color: var(--muted); font-size: 8px; }
.feed-audience { display: inline-flex; margin-top: 8px; padding: 4px 7px; border-radius: 999px; color: var(--green-dark); background: var(--green-soft); font-size: 7px; font-weight: 900; letter-spacing: .3px; text-transform: uppercase; }
.feed-post h3 { margin: 10px 0 6px; font-family: Georgia, serif; font-size: 22px; }
.feed-post p { margin-bottom: 12px; color: var(--ink-soft); font-size: 11px; line-height: 1.6; white-space: pre-wrap; }
.feed-image { display: block; max-height: 320px; max-width: 100%; margin: 10px 0 12px; border: 1px solid var(--line-soft); border-radius: 13px; object-fit: cover; }
.feed-actions { display: flex; align-items: center; flex-wrap: wrap; gap: 8px; }
.reaction-button { min-height: 32px; padding: 0 11px; border: 1px solid var(--line); border-radius: 20px; color: var(--ink-soft); background: white; font-size: 8px; font-weight: 900; }
.reaction-button.active { color: var(--green-dark); border-color: #b8ddeb; background: var(--green-soft); }
.reaction-button b { margin-left: 5px; color: inherit; font-size: 8px; }
.reaction-count { color: var(--muted); font-size: 8px; font-weight: 800; }
.guideline-editor {
  display: grid;
  margin-bottom: 20px;
  padding: 19px;
  grid-template-columns: minmax(220px, .8fr) minmax(180px, .75fr) minmax(180px, .75fr) minmax(260px, 1fr);
  gap: 12px;
  align-items: end;
  border: 1px solid var(--line-soft);
  border-radius: var(--radius);
  background: white;
  box-shadow: var(--shadow-sm);
}
.guideline-editor h2 { margin: 4px 0; font-size: 22px; }
.guideline-editor p { margin: 0; font-size: 9px; }
.guideline-editor label { color: var(--ink-soft); font-size: 8px; font-weight: 900; }
.guideline-editor input, .guideline-editor textarea { margin-top: 5px; font-size: 9px; }
.guideline-editor textarea { min-height: 88px; padding: 10px; resize: vertical; line-height: 1.45; }
.guideline-body-field { grid-column: span 2; }
.guideline-form-actions { display: flex; gap: 8px; align-items: center; }
.guideline-tools {
  display: grid;
  margin-bottom: 14px;
  padding: 12px;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 10px;
  align-items: end;
  border: 1px solid var(--line-soft);
  border-radius: 14px;
  background: white;
  box-shadow: var(--shadow-sm);
}
.guideline-tools label { color: var(--muted); font-size: 8px; font-weight: 900; letter-spacing: .5px; text-transform: uppercase; }
.guideline-tools input { margin-top: 5px; font-size: 9px; }
.guideline-list { display: flex; flex-direction: column; gap: 12px; }
.guideline-card {
  display: grid;
  padding: 18px;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 14px;
  border: 1px solid var(--line-soft);
  border-radius: 16px;
  background: white;
  box-shadow: var(--shadow-sm);
}
.guideline-card-header { display: flex; align-items: center; justify-content: space-between; gap: 12px; }
.guideline-category { display: inline-flex; padding: 4px 8px; border-radius: 999px; color: var(--green-dark); background: var(--green-soft); font-size: 7px; font-weight: 900; letter-spacing: .5px; text-transform: uppercase; }
.guideline-card time { color: var(--muted); font-size: 8px; }
.guideline-card h3 { margin: 10px 0 6px; font-family: Georgia, serif; font-size: 24px; }
.guideline-card p { margin: 0 0 12px; color: var(--ink-soft); font-size: 11px; line-height: 1.65; white-space: pre-wrap; }
.guideline-meta { display: flex; flex-wrap: wrap; gap: 8px; color: var(--muted); font-size: 8px; font-weight: 800; }
.guideline-file-link { display: inline-flex; margin-top: 12px; color: var(--green-dark); font-size: 9px; font-weight: 900; text-decoration: none; }
.guideline-actions { display: grid; min-width: 120px; align-content: start; gap: 7px; }
.guideline-actions .button { min-height: 34px; font-size: 8px; }
.upload-panel { display: flex; flex-direction: column; gap: 14px; }
.upload-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 11px; }
.upload-description { grid-column: span 2; }
.upload-file { grid-column: span 2; }

.print-queue-stats { display: grid; margin-bottom: 18px; grid-template-columns: repeat(3, 1fr); gap: 11px; }
.print-queue-stats div { padding: 17px; border: 1px solid var(--line-soft); border-radius: 13px; background: white; box-shadow: var(--shadow-sm); }
.print-queue-stats span, .print-queue-stats strong { display: block; }
.print-queue-stats span { color: var(--muted); font-size: 8px; font-weight: 800; letter-spacing: .6px; text-transform: uppercase; }
.print-queue-stats strong { margin-top: 2px; font-family: Georgia, serif; font-size: 30px; }
.print-job-list { display: flex; flex-direction: column; gap: 13px; }
.print-job-card {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 220px;
  gap: 16px;
  padding: 18px;
  border: 1px solid var(--line-soft);
  border-radius: 16px;
  background: white;
  box-shadow: var(--shadow-sm);
}
.print-job-header { display: flex; margin-bottom: 8px; align-items: center; justify-content: space-between; gap: 10px; }
.print-job-header time { color: var(--muted); font-size: 8px; }
.print-job-card h3 { margin: 3px 0 4px; font-family: Georgia, serif; font-size: 22px; }
.print-job-card p { margin-bottom: 12px; font-size: 10px; }
.print-settings-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
.print-settings-grid span { padding: 9px 10px; border: 1px solid var(--line-soft); border-radius: 10px; color: var(--ink-soft); background: #fbfdfe; font-size: 9px; }
.print-settings-grid b { display: block; margin-bottom: 2px; color: var(--muted); font-size: 7px; letter-spacing: .5px; text-transform: uppercase; }
.print-job-actions { display: grid; align-content: start; gap: 7px; }
.print-job-actions .button { min-height: 35px; font-size: 8px; }
.button-done { color: var(--green-dark); border-color: #bdddeb; background: var(--green-soft); cursor: default; }
.print-job-actions .danger-action:hover { border-color: #e2a7a7; color: #a33838; background: #fff4f4; }
.print-bin-panel { margin-top: 20px; padding: 20px; border: 1px solid var(--line-soft); border-radius: var(--radius); background: white; }
.print-bin-heading { display: grid; margin-bottom: 15px; align-items: end; grid-template-columns: minmax(0, 1fr) 150px auto; gap: 12px; }
.print-bin-heading h2 { margin: 4px 0; font-family: Georgia, serif; font-size: 21px; }
.print-bin-heading p { margin: 0; color: var(--muted); font-size: 9px; }
.print-bin-heading label { color: var(--muted); font-size: 8px; font-weight: 900; letter-spacing: .5px; text-transform: uppercase; }
.print-bin-heading label span { display: flex; margin-top: 5px; align-items: center; gap: 6px; color: var(--ink); font-size: 9px; text-transform: none; }
.print-bin-heading input { width: 72px; min-height: 36px; padding: 0 10px; border: 1px solid var(--line); border-radius: 10px; background: white; font: inherit; font-weight: 900; }
.print-bin-list { display: flex; flex-direction: column; gap: 9px; }
.print-bin-card { display: grid; padding: 12px; align-items: center; grid-template-columns: minmax(0, 1fr) auto; gap: 12px; border: 1px solid var(--line-soft); border-radius: 13px; background: #f7fbfc; }
.print-bin-card h3 { margin: 6px 0 3px; font-family: Georgia, serif; font-size: 16px; }
.print-bin-card p { margin: 0; color: var(--muted); font-size: 9px; }

.print-modal {
  position: fixed;
  z-index: 120;
  inset: 0;
  display: grid;
  padding: 20px;
  place-items: center;
  background: rgba(7, 24, 36, .62);
  backdrop-filter: blur(8px);
}
.print-modal-card {
  width: min(760px, 100%);
  max-height: min(760px, 92vh);
  padding: 22px;
  overflow: auto;
  border: 1px solid var(--line);
  border-radius: 20px;
  background: var(--paper);
  box-shadow: var(--shadow-lg);
}
.print-form-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 12px; }
.print-form-grid label { color: var(--ink-soft); font-size: 8px; font-weight: 800; }
.print-form-grid input, .print-form-grid select, .print-form-grid textarea {
  width: 100%;
  min-height: 41px;
  margin-top: 5px;
  padding: 0 10px;
  border: 1px solid var(--line);
  border-radius: 9px;
  color: var(--ink);
  background: white;
  font-size: 9px;
}
.print-form-grid textarea { min-height: 84px; padding: 10px; resize: vertical; line-height: 1.45; }
.print-collate-field { display: flex; min-height: 41px; margin-top: 18px; align-items: center; gap: 7px; }
.print-collate-field input { width: auto; min-height: auto; margin: 0; }
.print-notes-field { grid-column: 1 / -1; }
.print-modal-card .button-large { width: 100%; margin-top: 15px; }

.pd-heading { align-items: center; }
.pd-overview { display: grid; margin-bottom: 18px; grid-template-columns: .8fr 1.2fr; gap: 14px; }
.pd-score-card, .pd-policy-card, .pd-panel {
  padding: 19px;
  border: 1px solid var(--line-soft);
  border-radius: var(--radius);
  background: white;
  box-shadow: var(--shadow-sm);
}
.pd-score-card strong { display: block; margin: 4px 0; font-family: Georgia, serif; font-size: 46px; line-height: 1; }
.pd-score-card p, .pd-policy-card p, .pd-panel p { margin-bottom: 0; font-size: 9px; }
.pd-progress { height: 9px; margin-top: 14px; overflow: hidden; border-radius: 20px; background: #e6eef3; }
.pd-progress i { display: block; width: 0%; height: 100%; border-radius: inherit; background: linear-gradient(90deg, var(--green), var(--navy)); transition: width .25s ease; }
.pd-milestones { display: flex; margin-top: 10px; gap: 6px; flex-wrap: wrap; }
.pd-milestones span { padding: 4px 7px; border-radius: 20px; color: var(--muted); background: #edf3f7; font-size: 7px; font-weight: 900; }
.pd-milestones span.earned { color: var(--green-dark); background: var(--green-soft); }
.pd-layout { display: grid; align-items: start; grid-template-columns: minmax(0, 1fr) 340px; gap: 16px; }
.pd-main, .pd-side { display: flex; flex-direction: column; gap: 16px; }
.pd-side { position: sticky; top: 88px; }
.pd-form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.pd-form label { display: block; color: var(--ink-soft); font-size: 8px; font-weight: 800; }
.pd-form input, .pd-form select, .pd-form textarea { margin-top: 5px; font-size: 9px; }
.pd-form textarea { min-height: 84px; padding: 10px; resize: vertical; line-height: 1.45; }
.pd-notes-field { grid-column: 1 / -1; }
.pd-selected-points { display: flex; margin: 13px 0; padding: 10px 11px; align-items: center; justify-content: space-between; gap: 10px; border-radius: 10px; background: var(--green-soft); }
.pd-selected-points span { color: var(--green-dark); font-size: 14px; font-weight: 900; }
.pd-selected-points small { color: var(--muted); font-size: 8px; }
.pd-entry-list { display: flex; flex-direction: column; gap: 10px; }
.pd-entry {
  display: grid;
  grid-template-columns: 52px 1fr auto;
  gap: 12px;
  padding: 13px;
  border: 1px solid var(--line-soft);
  border-radius: 13px;
  background: #fbfdfe;
}
.pd-entry-points { display: grid; width: 52px; height: 52px; border-radius: 14px; place-items: center; color: white; background: var(--navy); font-size: 15px; font-weight: 900; }
.pd-entry strong, .pd-entry span { display: block; }
.pd-entry strong { color: var(--ink); font-size: 12px; }
.pd-entry span { color: var(--muted); font-size: 8px; }
.pd-entry p { margin: 6px 0 0; color: var(--ink-soft); font-size: 9px; }
.pd-entry-actions { display: flex; align-items: center; gap: 6px; }
.pd-entry-actions button { min-height: 31px; padding: 0 9px; border: 1px solid var(--line); border-radius: 8px; color: var(--ink-soft); background: white; font-size: 8px; font-weight: 800; }
.pd-entry-actions .danger-action:hover { border-color: #e2a7a7; color: #a33838; background: #fff4f4; }
.pd-leaderboard { display: flex; margin-top: 14px; flex-direction: column; gap: 11px; }
.pd-bar-row { display: grid; grid-template-columns: 1fr auto; gap: 7px; }
.pd-bar-row strong, .pd-bar-row span { display: block; }
.pd-bar-row strong { font-size: 9px; }
.pd-bar-row span { color: var(--muted); font-size: 7px; }
.pd-bar-score { color: var(--green-dark); font-size: 9px; font-weight: 900; }
.pd-bar-track { grid-column: 1 / -1; height: 8px; overflow: hidden; border-radius: 12px; background: #e9f0f4; }
.pd-bar-track i { display: block; width: var(--pd-width); height: 100%; border-radius: inherit; background: linear-gradient(90deg, var(--green), var(--navy)); }
.pd-category-guide { display: flex; margin-top: 13px; flex-direction: column; gap: 10px; }
.pd-category-card { padding: 11px; border: 1px solid var(--line-soft); border-radius: 11px; background: #fbfdfe; }
.pd-category-card strong { display: block; color: var(--ink); font-size: 10px; }
.pd-category-card p { margin: 3px 0 7px; font-size: 8px; }
.pd-category-card span { display: block; color: var(--muted); font-size: 8px; }

.admin-heading { align-items: center; }
.admin-shield { padding: 7px 10px; border: 1px solid #bdddeb; border-radius: 20px; color: var(--green-dark); background: var(--green-soft); font-size: 8px; font-weight: 800; letter-spacing: .5px; text-transform: uppercase; }
.security-banner { display: flex; margin-bottom: 18px; padding: 14px 16px; align-items: center; justify-content: space-between; gap: 18px; border: 1px solid #ecd58f; border-radius: 13px; background: #fff9e8; }
.security-banner strong { display: block; color: #7b5b16; font-size: 11px; }
.security-banner p { margin: 2px 0 0; color: #8c7743; font-size: 9px; }
.security-banner .button { flex: 0 0 auto; font-size: 9px; }
.admin-stats { display: grid; margin-bottom: 18px; grid-template-columns: repeat(6, 1fr); gap: 11px; }
.admin-stats div { padding: 16px; border: 1px solid var(--line-soft); border-radius: 13px; background: white; box-shadow: var(--shadow-sm); }
.admin-stats span, .admin-stats strong, .admin-stats small { display: block; }
.admin-stats span { color: var(--muted); font-size: 8px; font-weight: 800; letter-spacing: .6px; text-transform: uppercase; }
.admin-stats strong { margin: 2px 0; font-family: Georgia, serif; font-size: 28px; }
.admin-stats small { color: #9babb3; font-size: 8px; }
.admin-layout { display: grid; align-items: start; grid-template-columns: minmax(0, 1fr) 300px; gap: 16px; }
.admin-main, .admin-side { display: flex; flex-direction: column; gap: 16px; }
.admin-side { position: sticky; top: 88px; }
.admin-panel { padding: 18px; border: 1px solid var(--line-soft); border-radius: 15px; background: white; box-shadow: var(--shadow-sm); }
.admin-panel .section-heading { margin-bottom: 13px; }
.admin-panel .section-heading h2, .admin-form h2, .permission-card h2 { margin: 4px 0 0; font-size: 20px; }
.admin-search { position: relative; display: block; width: 210px; }
.admin-search span { position: absolute; left: 11px; bottom: 9px; color: var(--muted); }
.admin-search input { width: 100%; min-height: 34px; padding: 0 10px 0 27px; border: 1px solid var(--line); border-radius: 9px; font-size: 9px; }
.admin-table-wrap { overflow-x: auto; }
.admin-table { width: 100%; border-collapse: collapse; }
.admin-table th { padding: 8px 10px; border-bottom: 1px solid var(--line); color: var(--muted); text-align: left; font-size: 7px; font-weight: 900; letter-spacing: .7px; text-transform: uppercase; }
.admin-table td { padding: 11px 10px; border-bottom: 1px solid var(--line-soft); color: var(--ink-soft); font-size: 9px; vertical-align: middle; }
.admin-table tr:last-child td { border-bottom: 0; }
.admin-account { display: flex; min-width: 180px; align-items: center; gap: 8px; }
.admin-account .creator-dot { width: 28px; height: 28px; flex: 0 0 auto; }
.admin-account strong, .admin-account span { display: block; }
.admin-account strong { color: var(--ink); font-size: 10px; }
.admin-account span { color: var(--muted); font-size: 8px; }
.role-pill, .account-status { display: inline-flex; padding: 4px 7px; border-radius: 20px; font-size: 7px; font-weight: 900; text-transform: capitalize; }
.role-pill { color: var(--green-dark); background: var(--green-soft); }
.role-pill.teacher { color: var(--ink-soft); background: #eef3f5; }
.role-pill.owner { color: #164b74; background: #dff2fb; }
.role-switch { min-height: 29px; border: 1px solid var(--line); border-radius: 7px; color: var(--ink-soft); background: white; font-size: 7px; font-weight: 800; }
.account-status { color: #27784f; background: #e5f6ed; }
.account-status.inactive { color: #8d5c52; background: #faece9; }
.admin-actions { display: flex; min-width: 160px; gap: 5px; }
.admin-actions button { min-height: 29px; padding: 0 7px; border: 1px solid var(--line); border-radius: 7px; color: var(--ink-soft); background: white; font-size: 7px; font-weight: 800; }
.admin-actions button:hover { border-color: var(--green); color: var(--green-dark); }
.admin-actions .danger-action:hover { border-color: #e2a7a7; color: #a33838; background: #fff4f4; }
.admin-actions button:disabled { cursor: not-allowed; opacity: .35; }
.admin-form > p { margin: 5px 0 15px; font-size: 8px; }
.admin-form label { display: block; margin-bottom: 11px; color: var(--ink-soft); font-size: 8px; font-weight: 800; }
.admin-form input, .admin-form select, .admin-form textarea { width: 100%; min-height: 39px; margin-top: 5px; padding: 0 10px; border: 1px solid var(--line); border-radius: 8px; color: var(--ink); background: white; font-size: 9px; }
.admin-form textarea { min-height: 82px; padding: 10px; resize: vertical; line-height: 1.45; }
.admin-form .button-large { width: 100%; min-height: 43px; font-size: 10px; }
.password-rule { padding: 8px; border-radius: 7px; background: #f5f8fa; }
.studio-admin-panel { overflow: hidden; }
.studio-control-grid { display: grid; grid-template-columns: minmax(0, 1fr) minmax(280px, .86fr); gap: 14px; }
.studio-form { padding: 13px; border: 1px solid var(--line-soft); border-radius: 13px; background: #fbfdfe; }
.mini-section-heading { display: flex; margin-bottom: 12px; align-items: flex-start; justify-content: space-between; gap: 10px; }
.mini-section-heading strong, .mini-section-heading span { display: block; }
.mini-section-heading strong { color: var(--ink); font-size: 12px; }
.mini-section-heading span { color: var(--muted); font-size: 8px; }
.lesson-focus-list { display: flex; margin-bottom: 12px; flex-direction: column; gap: 9px; }
.lesson-focus-row { display: grid; grid-template-columns: 1.1fr .9fr auto; gap: 8px; padding: 10px; border: 1px solid var(--line); border-radius: 10px; background: white; }
.lesson-focus-row label { margin: 0; }
.lesson-focus-row .focus-instruction { grid-column: 1 / -1; }
.lesson-focus-row .focus-enabled { display: flex; min-height: 38px; margin-top: 18px; align-items: center; gap: 6px; color: var(--muted); font-size: 8px; font-weight: 800; }
.lesson-focus-row .focus-enabled input { width: auto; min-height: auto; margin: 0; }
.remove-focus-button { min-height: 31px; margin-top: 19px; padding: 0 8px; border: 1px solid #e2c4c4; border-radius: 8px; color: #9f3838; background: #fff7f7; font-size: 8px; font-weight: 800; }
.admin-form-actions { display: grid; grid-template-columns: 1fr 1fr; gap: 7px; }
.api-key-status { margin: -2px 0 12px; color: var(--muted); font-size: 8px; }
.danger-text { margin-top: 10px; color: #a33838; }
.permission-card #admin-permission-list { display: flex; margin-top: 13px; flex-direction: column; gap: 6px; }
.permission-item { display: flex; align-items: center; gap: 7px; color: var(--ink-soft); font-size: 8px; }
.permission-item::before { display: grid; width: 16px; height: 16px; border-radius: 50%; place-items: center; color: white; background: var(--green); content: "v"; font-size: 6px; font-weight: 900; }
.usage-filters { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; margin-bottom: 13px; }
.usage-summary { display: grid; grid-template-columns: repeat(4, 1fr); gap: 9px; margin-bottom: 14px; }
.usage-summary div { padding: 12px; border: 1px solid var(--line-soft); border-radius: 12px; background: var(--paper-soft); }
.usage-summary span, .usage-summary strong { display: block; }
.usage-summary span { color: var(--muted); font-size: 8px; font-weight: 900; letter-spacing: .5px; text-transform: uppercase; }
.usage-summary strong { margin-top: 3px; font-family: Georgia, serif; font-size: 25px; }
.usage-bars { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.usage-bar-group { padding: 13px; border: 1px solid var(--line-soft); border-radius: 13px; background: white; }
.usage-bar-group h3 { margin: 0 0 10px; font-size: 13px; }
.usage-bar-group p { margin: 0; color: var(--muted); font-size: 9px; }
.usage-bar-row { display: grid; grid-template-columns: 95px 1fr 28px; align-items: center; gap: 8px; margin: 7px 0; color: var(--muted); font-size: 8px; font-weight: 800; }
.usage-bar-row i { display: block; height: 8px; border-radius: 999px; background: linear-gradient(90deg, var(--blue), var(--green)); width: var(--bar); }
.usage-bar-row b { color: var(--ink); text-align: right; }
.license-note { margin: 0 0 13px; color: var(--muted); font-size: 9px; }
.school-create-form { margin-bottom: 14px; padding: 14px; border: 1px solid var(--line-soft); border-radius: 14px; background: var(--paper-soft); }
.school-create-form h3 { margin: 2px 0 11px; font-size: 16px; }
.school-create-form label { display: block; color: var(--ink-soft); font-size: 8px; font-weight: 900; }
.school-create-form input { width: 100%; min-height: 36px; margin-top: 5px; padding: 0 10px; border: 1px solid var(--line); border-radius: 9px; color: var(--ink); background: white; font-size: 9px; }
.school-create-grid { display: grid; grid-template-columns: 1.2fr .8fr; gap: 10px; }
.school-seat-grid { display: grid; grid-template-columns: repeat(5, 1fr); gap: 8px; margin: 10px 0 12px; }
.license-list { display: flex; flex-direction: column; gap: 12px; }
.license-card { padding: 13px; border: 1px solid var(--line-soft); border-radius: 14px; background: white; }
.license-card-heading { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-bottom: 11px; }
.license-card-heading strong, .license-card-heading span { display: block; }
.license-card-heading strong { color: var(--ink); font-size: 14px; }
.license-card-heading span { color: var(--muted); font-size: 8px; }
.license-role-grid { display: grid; grid-template-columns: repeat(5, 1fr); gap: 8px; }
.license-role-card { padding: 10px; border: 1px solid var(--line-soft); border-radius: 12px; background: var(--paper-soft); }
.license-role-card span, .license-role-card strong, .license-role-card small { display: block; }
.license-role-card span { color: var(--muted); font-size: 8px; font-weight: 900; letter-spacing: .4px; text-transform: uppercase; }
.license-role-card strong { margin-top: 4px; color: var(--ink); font-family: Georgia, serif; font-size: 20px; }
.license-role-card small { color: var(--muted); font-size: 8px; }
.license-role-card input { width: 100%; min-height: 30px; margin-top: 8px; padding: 0 8px; border: 1px solid var(--line); border-radius: 8px; background: white; color: var(--ink); font-size: 9px; font-weight: 800; }
.certificate-layout { display: grid; align-items: start; grid-template-columns: minmax(0, 1.2fr) minmax(340px, .8fr); gap: 16px; }
.certificate-programs { display: flex; flex-direction: column; gap: 12px; margin: 12px 0; }
.certificate-program-card { padding: 13px; border: 1px solid var(--line-soft); border-radius: 14px; background: var(--paper-soft); }
.certificate-program-head { display: grid; grid-template-columns: 1fr 1fr 1fr auto; align-items: end; gap: 9px; }
.certificate-term-grid { display: grid; grid-template-columns: 1fr 1fr .7fr; gap: 9px; margin-top: 10px; }
.certificate-term-grid label { margin: 0; }
.certificate-term-grid span { display: grid; grid-template-columns: 1fr .8fr; gap: 6px; }
.certificate-period-summary { margin-top: 12px; padding: 11px 12px; border: 1px solid #cfe3eb; border-radius: 12px; background: #f4fbff; }
.certificate-period-summary strong, .certificate-period-summary span { display: block; }
.certificate-period-summary strong { margin-bottom: 6px; color: var(--green-dark); font-size: 9px; }
.certificate-period-summary span { color: var(--ink-soft); font-size: 8px; line-height: 1.45; }
.certificate-period-warning { border-color: #efc27a; background: #fff8e8; }
.certificate-period-warning strong { color: #8d5b13; }
.certificate-period-warning span { color: #7d5c26; }
.certificate-records-tile { display: flex; width: 100%; min-height: 235px; flex-direction: column; align-items: flex-start; justify-content: center; gap: 8px; text-align: left; cursor: pointer; transition: transform .18s, box-shadow .18s, border-color .18s; }
.certificate-records-tile:hover { transform: translateY(-2px); border-color: var(--green); box-shadow: var(--shadow-lg); }
.certificate-records-tile h2 { margin: 0; font-size: 25px; }
.certificate-records-tile strong { color: var(--navy); font-family: Georgia, serif; font-size: 54px; line-height: .9; }
.certificate-records-tile p { max-width: 320px; margin: 0; color: var(--muted); font-size: 10px; line-height: 1.45; }
.certificate-records-panel { margin-top: 16px; }
.certificate-record-tools { display: flex; align-items: center; justify-content: flex-end; gap: 8px; flex-wrap: wrap; }
.certificate-card { display: flex; align-items: center; justify-content: space-between; gap: 14px; padding: 14px; border: 1px solid var(--line-soft); border-radius: 14px; background: white; box-shadow: var(--shadow-sm); }
.certificate-card + .certificate-card { margin-top: 10px; }
.certificate-card h3 { margin: 3px 0; font-size: 18px; }
.certificate-card p { margin: 0; color: var(--muted); font-size: 9px; }
.certificate-actions { display: flex; gap: 7px; flex-wrap: wrap; justify-content: flex-end; }
.certificate-preview-panel { margin-top: 16px; }
.certificate-preview-shell { overflow-x: auto; padding: 16px; border-radius: 16px; background: #dfeaf0; }
.attestation-page { position: relative; width: min(100%, 820px); min-height: 1120px; margin: 0 auto; padding: 72px 72px 52px; color: #101820; background: white; font-family: Georgia, "Times New Roman", serif; box-shadow: 0 15px 40px rgba(18, 52, 72, .14); }
.attestation-header { display: flex; align-items: center; gap: 18px; padding-bottom: 10px; border-bottom: 2px solid #101820; }
.attestation-header img { width: 128px; height: 88px; object-fit: contain; }
.attestation-header h2 { margin: 0; font-family: Arial, sans-serif; font-size: 34px; font-weight: 400; letter-spacing: .2px; }
.attestation-header p { margin: 3px 0; color: #101820; font-family: Arial, sans-serif; font-size: 12px; line-height: 1.25; }
.attestation-page h1 { margin: 74px 0 55px; text-align: center; text-decoration: underline; font-size: 17px; letter-spacing: .3px; }
.attestation-page p { color: #101820; font-size: 16px; line-height: 1.55; }
.attestation-greeting { margin-top: 0; }
.attestation-table { width: 100%; margin: 58px 0 48px; border-collapse: collapse; }
.attestation-table th { padding: 0 0 10px; color: #101820; text-align: left; text-decoration: underline; font-size: 16px; font-style: italic; }
.attestation-table td { padding: 9px 14px 9px 0; vertical-align: top; color: #101820; font-size: 16px; line-height: 1.35; }
.attestation-table td:nth-child(3), .attestation-table td:nth-child(4) { width: 90px; text-align: center; }
.attestation-hours { margin-top: 28px; }
.attestation-purpose { margin-top: 100px; }
.attestation-signature { display: flex; justify-content: space-between; margin-top: 128px; }
.attestation-signature p { min-width: 220px; }
.attestation-signature p:last-child { text-align: right; }
.attestation-page footer { position: absolute; right: 38px; bottom: 24px; left: 38px; padding-top: 5px; border-top: 1px solid #101820; color: #101820; font-family: Arial, sans-serif; font-size: 11px; text-align: center; }
.audit-list { display: flex; flex-direction: column; }
.audit-event { display: grid; padding: 10px 1px; align-items: center; grid-template-columns: 30px 1fr auto; gap: 9px; border-bottom: 1px solid var(--line-soft); }
.audit-event:last-child { border-bottom: 0; }
.audit-icon { display: grid; width: 27px; height: 27px; border-radius: 8px; place-items: center; color: var(--green-dark); background: var(--green-soft); font-size: 7px; font-weight: 900; }
.audit-event strong, .audit-event span { display: block; }
.audit-event strong { font-size: 9px; }
.audit-event span { color: var(--muted); font-size: 7px; }
.audit-event time { color: var(--muted); font-size: 7px; }

.generating-overlay { position: fixed; z-index: 100; inset: 0; display: grid; padding: 20px; place-items: center; background: rgba(9,34,46,.68); backdrop-filter: blur(9px); }
.generating-card { width: min(420px, 100%); padding: 38px; border-radius: 20px; background: white; box-shadow: var(--shadow-lg); text-align: center; }
.generating-card h2 { margin: 12px 0 22px; font-size: 27px; }
.generation-orbit { position: relative; width: 75px; height: 75px; margin: 0 auto 24px; border: 1px solid #d4e5df; border-radius: 50%; animation: orbit 2s linear infinite; }
.generation-orbit::after { position: absolute; inset: 15px; border-radius: 50%; background: var(--green-soft); content: "AI"; display: grid; place-items: center; color: var(--green-dark); font-size: 9px; font-weight: 900; }
.generation-orbit i { position: absolute; width: 8px; height: 8px; border-radius: 50%; background: var(--green); }
.generation-orbit i:nth-child(1) { top: -4px; left: 34px; }
.generation-orbit i:nth-child(2) { right: 2px; bottom: 10px; background: var(--peach); }
.generation-orbit i:nth-child(3) { left: 1px; bottom: 12px; background: var(--yellow); }
@keyframes orbit { to { transform: rotate(360deg); } }
.generation-steps { display: flex; padding: 13px; flex-direction: column; gap: 7px; border-radius: 11px; background: #f6f9f7; text-align: left; }
.generation-steps span { color: #9ba8ad; font-size: 9px; font-weight: 700; }
.generation-steps span::before { display: inline-block; width: 14px; margin-right: 7px; color: #c9d3d3; content: "o"; text-align: center; }
.generation-steps .done { color: var(--green-dark); }
.generation-steps .done::before { content: "v"; }
.generation-steps .active { color: var(--ink); }
.generation-steps .active::before { color: var(--peach); content: "..."; }
.toast { position: fixed; z-index: 110; right: 25px; bottom: 25px; padding: 12px 16px; border-radius: 10px; color: white; background: var(--navy); box-shadow: var(--shadow-lg); font-size: 10px; font-weight: 700; opacity: 0; pointer-events: none; transform: translateY(12px); transition: opacity .25s, transform .25s; }
.toast.show { opacity: 1; transform: translateY(0); }

body.theme-dark .login-screen,
body.theme-dark .login-panel,
body.theme-dark .sidebar,
body.theme-dark .week-snapshot,
body.theme-dark .resource-row,
body.theme-dark .insight-card,
body.theme-dark .form-section,
body.theme-dark .type-option,
body.theme-dark .creation-summary,
body.theme-dark .edit-panel,
body.theme-dark .bank-tools,
body.theme-dark .resource-card,
body.theme-dark .empty-state,
body.theme-dark .saved-stats div,
body.theme-dark .feed-composer,
body.theme-dark .upload-panel,
body.theme-dark .feed-post,
body.theme-dark .feed-audience-field,
body.theme-dark .guideline-editor,
body.theme-dark .guideline-tools,
body.theme-dark .guideline-card,
body.theme-dark .print-queue-stats div,
body.theme-dark .print-job-card,
body.theme-dark .print-bin-panel,
body.theme-dark .print-bin-card,
body.theme-dark .usage-summary div,
body.theme-dark .usage-bar-group,
body.theme-dark .school-create-form,
body.theme-dark .license-card,
body.theme-dark .license-role-card,
body.theme-dark .certificate-program-card,
body.theme-dark .certificate-period-summary,
body.theme-dark .certificate-records-tile,
body.theme-dark .certificate-records-panel,
body.theme-dark .certificate-card,
body.theme-dark .print-modal-card,
body.theme-dark .pd-score-card,
body.theme-dark .pd-policy-card,
body.theme-dark .pd-panel,
body.theme-dark .admin-stats div,
body.theme-dark .admin-panel,
body.theme-dark .studio-form,
body.theme-dark .lesson-focus-row,
body.theme-dark .generating-card {
  background: var(--paper);
  border-color: var(--line);
}

body.theme-dark .topbar {
  background: rgba(7, 24, 36, .88);
  border-color: var(--line-soft);
}

body.theme-dark .notification-panel,
body.theme-dark .notification-panel::before {
  background: var(--paper);
  border-color: var(--line);
}

body.theme-dark .global-search input,
body.theme-dark .login-card input,
body.theme-dark .edit-panel input,
body.theme-dark .edit-panel textarea,
body.theme-dark .creator-form select,
body.theme-dark .bank-tools input,
body.theme-dark .bank-tools select,
body.theme-dark .upload-panel input,
body.theme-dark .upload-panel select,
body.theme-dark .upload-panel textarea,
body.theme-dark .feed-composer input,
body.theme-dark .feed-composer textarea,
body.theme-dark .guideline-editor input,
body.theme-dark .guideline-editor textarea,
body.theme-dark .guideline-tools input,
body.theme-dark .print-form-grid input,
body.theme-dark .print-form-grid select,
body.theme-dark .print-form-grid textarea,
body.theme-dark .print-bin-heading input,
body.theme-dark .pd-form input,
body.theme-dark .pd-form select,
body.theme-dark .pd-form textarea,
body.theme-dark .admin-search input,
body.theme-dark .admin-form input,
body.theme-dark .admin-form select,
body.theme-dark .admin-form textarea,
body.theme-dark .school-create-form input,
body.theme-dark .license-role-card input {
  color: var(--ink);
  background: #0b2030;
  border-color: var(--line);
}

body.theme-dark input::placeholder,
body.theme-dark textarea::placeholder {
  color: #7193aa;
}

body.theme-dark .button-secondary,
body.theme-dark .icon-button,
body.theme-dark .reaction-button,
body.theme-dark .bank-card-actions button,
body.theme-dark .pd-entry-actions button,
body.theme-dark .admin-actions button,
body.theme-dark .role-switch {
  color: var(--ink-soft);
  background: #0b2030;
  border-color: var(--line);
}

body.theme-dark .button-secondary:hover,
body.theme-dark .icon-button:hover,
body.theme-dark .reaction-button:hover,
body.theme-dark .bank-card-actions button:hover,
body.theme-dark .pd-entry-actions button:hover,
body.theme-dark .admin-actions button:hover,
body.theme-dark .role-switch:hover {
  border-color: var(--green);
  color: var(--ink);
  box-shadow: var(--shadow-sm);
}

body.theme-dark .button-primary,
body.theme-dark .button-generate,
body.theme-dark .nav-item.active .nav-icon {
  color: #052033;
}

body.theme-dark .bank-card-actions button.active,
body.theme-dark .bank-favorites-toggle.active {
  color: #8be6bd;
  background: #123524;
  border-color: #256249;
}

body.theme-dark .brand-mark,
body.theme-dark .paper-logo,
body.theme-dark .global-search kbd,
body.theme-dark .nav-badge {
  background: #0b2030;
  border-color: var(--line);
}

body.theme-dark .nav-item:hover {
  color: var(--ink);
  background: #102f44;
}

body.theme-dark .nav-item.active {
  color: var(--ink);
  background: linear-gradient(90deg, #123a52, #0b2739);
}

body.theme-dark .nav-icon,
body.theme-dark .sidebar-tip {
  border-color: var(--line);
}

body.theme-dark .sidebar-tip,
body.theme-dark .fine-tune-mode-switch,
body.theme-dark .ai-fine-tune-box,
body.theme-dark .curriculum-note,
body.theme-dark .type-illustration,
body.theme-dark .template-strip,
body.theme-dark .pd-entry,
body.theme-dark .pd-category-card,
body.theme-dark .print-settings-grid span,
body.theme-dark .password-rule,
body.theme-dark .generation-steps {
  background: #0b2030;
  border-color: var(--line-soft);
}

body.theme-dark .fine-tune-mode-switch button.active {
  color: var(--navy-deep);
  background: var(--green);
}

body.theme-dark .paper-stage {
  background: #0b2030;
  border-color: var(--line);
}

body.theme-dark .resource-row:hover,
body.theme-dark .resource-card:hover {
  border-color: var(--green);
}

body.theme-dark .bank-card {
  background: linear-gradient(140deg, #123a52, #0b2739);
}

body.theme-dark .bank-card p,
body.theme-dark .bank-card .action-kicker,
body.theme-dark .bank-card .card-link {
  color: var(--ink-soft);
}

body.theme-dark .progress-track,
body.theme-dark .topic-bars i,
body.theme-dark .pd-progress,
body.theme-dark .pd-bar-track {
  background: #183449;
}

body.theme-dark .tag-row span,
body.theme-dark .pd-milestones span,
body.theme-dark .feed-audience,
body.theme-dark .guideline-category,
body.theme-dark .role-pill.teacher {
  background: #183449;
  color: var(--ink-soft);
}

body.theme-dark .security-banner {
  border-color: #6f5720;
  background: #2a2413;
}

body.theme-dark .security-banner strong,
body.theme-dark .security-banner p {
  color: #f0cf73;
}

body.theme-dark .account-status {
  color: #90e1b8;
  background: #123524;
}

body.theme-dark .account-status.inactive,
body.theme-dark .login-error {
  color: #ffb5aa;
  background: #321819;
  border-color: #714041;
}

body.theme-dark .remove-focus-button,
body.theme-dark .admin-actions .danger-action:hover,
body.theme-dark .pd-entry-actions .danger-action:hover {
  color: #ffb5aa;
  background: #321819;
  border-color: #714041;
}

body.theme-dark .resource-thumb,
body.theme-dark .resource-card-thumb,
body.theme-dark .creator-dot,
body.theme-dark .avatar,
body.theme-dark .feed-post-avatar,
body.theme-dark .form-section-title > span,
body.theme-dark .notification-item b,
body.theme-dark .audit-icon {
  color: var(--ink);
}

body.theme-dark .activity-paper {
  --ink: #193343;
  --ink-soft: #315d78;
  --muted: #5e7f94;
  --line: #c5d9e6;
  --line-soft: #dcebf3;
  --navy: #0f568f;
  --navy-deep: #073b67;
  --green: #208fc6;
  --green-dark: #0f679f;
  --green-soft: #d9f0fb;
  --peach: #48aeda;
  --peach-soft: #e7f7fd;
  --purple: #1d78b5;
  --purple-soft: #dceff8;
  color: #193343;
  background: white;
}

body.theme-dark .activity-paper .paper-logo {
  background: white;
  border-color: #c5d9e6;
}

body.theme-dark .activity-paper .paper-meta span {
  color: #315d78;
  background: #f1f5f3;
}

body.theme-dark .activity-paper .template-strip {
  color: #315d78;
  background: #f4f8f9;
}

@media (max-width: 1120px) {
  :root { --sidebar: 218px; }
  .resource-grid { grid-template-columns: repeat(2, 1fr); }
  .field-grid.three-fields { grid-template-columns: 1fr 1fr; }
  .type-options { grid-template-columns: 1fr; }
  .type-option { display: grid; min-height: 83px; padding: 11px; align-items: center; grid-template-columns: 90px 1fr; column-gap: 12px; }
  .type-illustration { grid-row: span 2; }
  .type-option strong { margin: 0; }
  .creator-layout { grid-template-columns: minmax(0, 1fr) 270px; }
  .editor-layout { grid-template-columns: minmax(0, 1fr) 300px; }
  .feed-composer { grid-template-columns: 1fr 1fr; }
  .feed-composer > div, .feed-composer button { grid-column: 1 / -1; }
  .guideline-editor { grid-template-columns: 1fr 1fr; }
  .guideline-editor > div:first-child, .guideline-body-field, .guideline-form-actions { grid-column: 1 / -1; }
  .upload-grid { grid-template-columns: 1fr 1fr; }
  .print-job-card { grid-template-columns: 1fr; }
  .print-job-actions { grid-template-columns: repeat(3, 1fr); }
  .print-bin-heading { grid-template-columns: 1fr; }
  .print-bin-heading button { width: max-content; }
  .pd-layout, .pd-overview { grid-template-columns: 1fr; }
  .pd-side { position: static; }
  .board-grid { grid-template-columns: repeat(3, 1fr); }
  .resource-row { grid-template-columns: 48px 1fr .8fr auto; }
  .resource-row .resource-rating { display: none; }
  .admin-layout, .certificate-layout { grid-template-columns: 1fr; }
  .admin-side { position: static; display: grid; grid-template-columns: 1fr 1fr; }
  .usage-bars, .usage-summary, .usage-filters, .school-create-grid, .school-seat-grid, .license-role-grid, .certificate-program-head, .certificate-term-grid { grid-template-columns: 1fr; }
  .studio-control-grid { grid-template-columns: 1fr; }
}

@media (max-width: 900px) {
  .login-screen { grid-template-columns: 1fr; }
  .login-story { display: none; }
  .login-panel { padding: 30px; }
  .login-mobile-brand { display: flex; }
  .app-shell { display: block; }
  .sidebar { transform: translateX(-105%); transition: transform .25s; box-shadow: var(--shadow-lg); }
  .sidebar.open { transform: translateX(0); }
  .main-content { margin-left: 0; }
  .mobile-menu-button { display: grid; }
  .page-location { display: none; }
  .global-search { display: none; }
  .topbar { height: 62px; }
  .creator-layout, .editor-layout { grid-template-columns: 1fr; }
  .creation-summary, .edit-panel { position: static; max-height: none; }
  .creation-summary { order: -1; }
  .preview-heading { align-items: flex-start; flex-direction: column; }
  .editor-layout .edit-panel { order: -1; }
  .bank-tools { grid-template-columns: 1fr 1fr; }
  .admin-stats { grid-template-columns: 1fr 1fr; }
  .feed-composer { grid-template-columns: 1fr; }
  .guideline-editor, .guideline-tools, .guideline-card { grid-template-columns: 1fr; }
  .guideline-actions { grid-template-columns: 1fr 1fr; }
  .upload-description, .upload-file { grid-column: 1 / -1; }
  .pd-form-grid { grid-template-columns: 1fr; }
  .print-queue-stats, .print-form-grid, .print-settings-grid { grid-template-columns: 1fr; }
  .print-collate-field, .print-notes-field { grid-column: auto; }
}

@media (max-width: 680px) {
  .screen-wrap { padding-top: 28px; }
  .top-create { display: none; }
  .welcome-row, .page-heading { align-items: flex-start; flex-direction: column; }
  .week-snapshot { width: 100%; margin-top: 20px; }
  .action-grid, .dashboard-lower, .resource-grid, .saved-stats, .admin-stats, .admin-side, .upload-grid, .print-job-actions { grid-template-columns: 1fr; }
  .action-card { min-height: 235px; }
  .compact-list .resource-row:nth-child(n+3) { display: none; }
  .resource-row { grid-template-columns: 43px 1fr auto; }
  .resource-row .resource-meta, .resource-row .resource-rating { display: none; }
  .field-grid, .field-grid.three-fields, .bank-tools { grid-template-columns: 1fr; }
  .feed-post { grid-template-columns: 1fr; }
  .guideline-actions { grid-template-columns: 1fr; }
  .upload-description, .upload-file { grid-column: auto; }
  .pd-entry { grid-template-columns: 1fr; }
  .pd-entry-actions { flex-wrap: wrap; }
  .wizard-progress { display: none; }
  .preview-actions { width: 100%; flex-wrap: wrap; }
  .preview-actions .button { flex: 1; font-size: 9px; }
  .activity-paper { min-height: auto; padding: 22px; }
  .paper-header h2 { font-size: 22px; }
  .board-grid, .role-card-grid, .prompt-card-grid, .jigsaw-grid, .thinking-grid, .quote-grid, .gallery-grid, .gap-handouts { grid-template-columns: 1fr 1fr; }
  .board-cell { min-height: 100px; }
  .bank-heading .button { width: 100%; }
  .admin-heading { align-items: flex-start; }
  .security-banner { align-items: flex-start; flex-direction: column; }
  .admin-panel .section-heading { align-items: flex-start; flex-direction: column; }
  .admin-search { width: 100%; }
  .lesson-focus-row { grid-template-columns: 1fr; }
  .lesson-focus-row .focus-enabled, .remove-focus-button { margin-top: 0; }
  .admin-form-actions { grid-template-columns: 1fr; }
}

@media print {
  body { background: white; }
  .sidebar, .topbar, .preview-heading, .edit-panel, .paper-toolbar, .toast, .print-modal { display: none !important; }
  .main-content, .screen-wrap { width: 100%; margin: 0; padding: 0; }
  .screen { display: none !important; }
  .screen[data-screen="preview"] { display: block !important; }
  .editor-layout { display: block; }
  .paper-stage { padding: 0; border: 0; background: white; }
  .activity-paper { min-height: 0; padding: 10mm; box-shadow: none; }
}
