/* =============================================
   Mj Apartment Management Docs — GarageMaster UI
   Extracted from index.html (inline <style>)
   ============================================= */
:root {
  --brand: #5840BB;
  --brand-hover: #3D2A9E;
  --brand-light: #5840BB;
  --brand-soft: #EDE8FF;
  --brand-glow: rgba(88,64,187,.25);
  --ink: #1A1D23;
  --ink-light: #3D4250;
  --ink-muted: #7C818D;
  --surface: #FFFFFF;
  --page: #F5F6F8;
  --border: #E4E7EC;
  --border-light: #F0F1F4;
  --sidebar-bg: #FAFBFC;
  --code-bg: #1B2030;
  --success: #0D9E52;
  --warning: #D9850B;
  --danger: #D93025;
  --info: #4632A8;
  --r-sm: 6px;
  --r-md: 10px;
  --r-lg: 14px;
  --r-xl: 20px;
  --shadow-xs: 0 1px 2px rgba(0,0,0,.04);
  --shadow-sm: 0 2px 8px rgba(0,0,0,.06);
  --shadow-md: 0 4px 16px rgba(0,0,0,.08);
  --shadow-lg: 0 8px 30px rgba(0,0,0,.10);
  --shadow-xl: 0 16px 50px rgba(0,0,0,.12);
  --font-body: 'Plus Jakarta Sans', sans-serif;
  --font-display: 'Space Grotesk', sans-serif;
  --font-mono: 'JetBrains Mono', monospace;
  --ease: cubic-bezier(.4,0,.2,1);
  --navbar-h: 60px;
  --sidebar-w: 280px;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--font-body);font-size:16px;line-height:1.7;color:var(--ink);background:var(--page);overflow-x:hidden;-webkit-font-smoothing:antialiased;font-style:normal}

/* Reset italic on all elements that browsers render italic by default */
i,em,cite,dfn,var,address,blockquote,q,caption,small,abbr{font-style:normal}
/* Ensure the full document inherits normal font-style */
html,body,div,span,p,h1,h2,h3,h4,h5,h6,ul,ol,li,
table,thead,tbody,tr,td,th,section,article,nav,header,footer,main,aside,
input,button,select,textarea,label{font-style:normal}

/* Safety: anything using the brand solid background should keep text readable */
.gm-hero,
.welcome-banner,
.wizard-intro-banner,
.section-icon,
.step-number,
.req-icon,
.pf-icon,
.installation-tabs .nav-pills .nav-link.active,
.wizard-nav-btn.primary,
.back-to-top{
  color:#fff;
}

::-webkit-scrollbar{width:6px;height:6px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--border);border-radius:99px}
::-webkit-scrollbar-thumb:hover{background:var(--ink-muted)}

#progress-bar{position:fixed;top:0;left:0;height:3px;width:0%;background:var(--brand);z-index:10001;transition:width .15s linear;pointer-events:none}

/* NAVBAR */
.gm-navbar{
  position:fixed;top:0;left:0;right:0;
  height:var(--navbar-h);
  background:rgba(255,255,255,.92);
  backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  border-bottom:1px solid var(--border);
  z-index:1000;
  display:flex;align-items:center;
  padding:0 24px;
  transition:box-shadow .3s var(--ease);
}
.gm-navbar.scrolled{box-shadow:var(--shadow-sm)}
.gm-navbar-brand{display:flex;align-items:center;gap:10px;text-decoration:none;flex-shrink:0}
.navbar-logo-img{height:36px;width:auto;display:block;object-fit:contain}

/* AMS hero logo */
.ams-hero-logo{
    display:flex;
    align-items:center;
    gap:12px; /* space between logo and text */
}

.ams-hero-logo img{
    height:72px;
    width:auto;
    object-fit:contain;
    background-color:white;
    border-radius:50%;
    padding:4px;
    margin-bottom:0; /* remove bottom space */
}
.gm-nav-links{display:flex;align-items:center;gap:4px;margin-left:auto}
.gm-nav-links a{
  color:var(--ink-muted);font-size:.95rem;font-weight:500;
  padding:6px 14px;border-radius:var(--r-sm);
  text-decoration:none;transition:all .2s var(--ease);
}
.gm-nav-links a:hover{color:var(--ink);background:var(--border-light)}
.gm-nav-links a.active{color:var(--brand);background:var(--brand-soft)}
.gm-buy-btn{
  margin-left:12px;
  background:var(--brand);color:#fff !important;
  padding:8px 20px;border-radius:99px;
  font-size:.95rem;font-weight:600;
  text-decoration:none;display:inline-flex;align-items:center;gap:6px;
  transition:all .2s var(--ease);box-shadow:0 2px 8px var(--brand-glow);
}

/* AFTER */
a.gm-buy-btn:hover{background:var(--brand-hover);color:#fff !important;transform:translateY(-1px);box-shadow:0 4px 16px var(--brand-glow)}
.gm-mob-toggle{
  display:none;background:none;border:none;cursor:pointer;
  width:36px;height:36px;border-radius:var(--r-sm);
  align-items:center;justify-content:center;
  color:var(--ink);font-size:1.3rem;margin-left:auto;
}

/* PAGE GRID */
#app{
  display:grid;
  grid-template-columns:var(--sidebar-w) 1fr;
  padding-top:var(--navbar-h);
  min-height:100vh;
}

/* SIDEBAR */
.gm-sidebar{
  position:sticky;
  top:var(--navbar-h);
  height:calc(100vh - var(--navbar-h));
  width:var(--sidebar-w);
  background:var(--sidebar-bg);
  border-right:1px solid var(--border);
  overflow-y:auto;overflow-x:hidden;
  display:flex;flex-direction:column;
  align-self:start;
  z-index:900;
  scroll-behavior:smooth;
}
.sidebar-head{padding:20px 20px 14px;border-bottom:1px solid var(--border);flex-shrink:0}
.sidebar-head h6{font-family:var(--font-display);font-size:.88rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-muted);margin-bottom:10px;display:flex;align-items:center;gap:6px}
.sidebar-search{position:relative}
.sidebar-search input{
  width:100%;padding:8px 12px 8px 34px;
  border:1.5px solid var(--border);border-radius:var(--r-sm);
  font-family:var(--font-body);font-size:.95rem;color:var(--ink);
  background:var(--surface);outline:none;
  transition:border-color .2s var(--ease),box-shadow .2s var(--ease);
}
.sidebar-search input:focus{border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-glow)}
.sidebar-search input::placeholder{color:var(--ink-muted)}
.sidebar-search .s-icon{position:absolute;left:11px;top:50%;transform:translateY(-50%);font-size:.95rem;color:var(--ink-muted);pointer-events:none}

.sidebar-nav{padding:10px 0 30px;flex:1}
.snav-group{margin-bottom:2px}
.snav-label{
  display:block;padding:16px 20px 4px;
  font-size:.9rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
  color:var(--brand);opacity:.7;
}
.snav-group ul{list-style:none;padding:0;margin:0}
.snav-link{
  display:flex;align-items:center;gap:8px;
  padding:7px 20px;margin:0 8px;border-radius:var(--r-sm);
  color:var(--ink-light);font-size:1.03rem;font-weight:500;
  text-decoration:none;transition:all .15s var(--ease);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.snav-link i{font-size:1.0rem;opacity:.55;width:16px;text-align:center;flex-shrink:0}
.snav-link:hover{color:var(--ink);background:rgba(0,0,0,.04)}
.snav-link.active{color:var(--brand);background:var(--brand-soft);font-weight:600}
.snav-link.wizard{background:var(--brand-soft);color:var(--brand);font-weight:600;border:1px dashed rgba(88,64,187,.3)}

.snav-dropdown-btn{
  display:flex;align-items:center;gap:8px;width:calc(100% - 16px);
  padding:7px 12px 7px 20px;margin:0 8px;border-radius:var(--r-sm);
  color:var(--ink-light);font-size:1.03rem;font-weight:500;
  background:none;border:none;cursor:pointer;font-family:var(--font-body);
  text-align:left;transition:all .15s var(--ease);
}
.snav-dropdown-btn i.ico{font-size:1.0rem;opacity:.55;width:16px;text-align:center;flex-shrink:0}
.snav-dropdown-btn span{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.snav-dropdown-btn .arrow{
  font-size:.55rem;margin-left:auto;opacity:.4;
  transition:transform .25s var(--ease);flex-shrink:0;
}
.snav-dropdown-btn:hover{color:var(--ink);background:rgba(0,0,0,.04)}
.snav-dropdown-btn.open{color:var(--brand);font-weight:600;background:var(--brand-soft)}
.snav-dropdown-btn.open .arrow{transform:rotate(90deg);opacity:.8}

.snav-dropdown{
  max-height:0;overflow:hidden;opacity:0;
  transition:max-height .35s var(--ease),opacity .25s var(--ease);
}
.snav-dropdown.open{max-height:2400px;opacity:1}
.snav-dropdown a{
  display:flex;align-items:center;gap:7px;
  padding:5px 20px 5px 48px;margin:0 8px;border-radius:var(--r-sm);
  color:var(--ink-muted);font-size:1.0rem;font-weight:400;
  text-decoration:none;transition:all .15s var(--ease);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.snav-dropdown a i{font-size:1.0rem;opacity:.5;width:14px;text-align:center;flex-shrink:0}
.snav-dropdown a:hover{color:var(--ink);background:rgba(0,0,0,.03)}
.snav-dropdown a.active{color:var(--brand);background:var(--brand-soft);font-weight:600}

/* Nested role sub-dropdowns */
.snav-role-btn{
  display:flex;align-items:center;gap:7px;width:calc(100% - 16px);
  padding:5px 12px 5px 44px;margin:0 8px;border-radius:var(--r-sm);
  color:var(--ink-muted);font-size:.95rem;font-weight:500;
  background:none;border:none;cursor:pointer;font-family:var(--font-body);
  text-align:left;transition:all .15s var(--ease);
}
.snav-role-btn i.rico{font-size:.9rem;opacity:.5;width:14px;text-align:center;flex-shrink:0}
.snav-role-btn span{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:.95rem}
.snav-role-btn .rarrow{
  font-size:.5rem;margin-left:auto;opacity:.4;
  transition:transform .25s var(--ease);flex-shrink:0;
}
.snav-role-btn:hover{color:var(--ink);background:rgba(0,0,0,.03)}
.snav-role-btn.open{color:var(--brand);font-weight:600;background:var(--brand-soft)}
.snav-role-btn.open .rarrow{transform:rotate(90deg);opacity:.8}

.snav-sub-dropdown{
  max-height:0;overflow:hidden;opacity:0;
  transition:max-height .3s var(--ease),opacity .2s var(--ease);
}
.snav-sub-dropdown.open{max-height:1200px;opacity:1}
.snav-sub-dropdown a{
  display:flex;align-items:center;gap:7px;
  padding:4px 12px 4px 64px;margin:0 8px;border-radius:var(--r-sm);
  color:var(--ink-muted);font-size:.88rem;font-weight:400;
  text-decoration:none;transition:all .15s var(--ease);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.snav-sub-dropdown a i{font-size:.88rem;opacity:.45;width:13px;text-align:center;flex-shrink:0}
.snav-sub-dropdown a:hover{color:var(--ink);background:rgba(0,0,0,.03)}
.snav-sub-dropdown a.active{color:var(--brand);background:var(--brand-soft);font-weight:600}

/* MAIN CONTENT */
.gm-main{
  min-width:0;
  overflow-x:clip;
  background:var(--page);
}

/* HERO */
.gm-hero{
  background:var(--brand); /* Home bg requested */
  padding:56px 0 50px;
  position:relative;overflow:hidden;
}
.gm-hero::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse at 80% 20%,rgba(255,255,255,.12),transparent 60%),
             radial-gradient(ellipse at 20% 80%,rgba(255,255,255,.10),transparent 50%);
  pointer-events:none;
}
.gm-hero .hero-inner{position:relative;z-index:1;padding:0 48px;max-width:1200px}
.hero-badge{
  display:inline-flex;align-items:center;gap:6px;
  background:rgba(88,64,187,.18);border:1px solid rgba(88,64,187,.30);
  color:#ffffff;padding:6px 16px;border-radius:99px;
  font-size:.93rem;font-weight:600;margin-bottom:18px;
}
.hero-badge i{font-size:.88rem}
.gm-hero h1{
  font-family:var(--font-display);font-size:clamp(1.6rem,3.5vw,2.4rem);
  font-weight:800;color:#fff;line-height:1.2;margin-bottom:14px;
  font-size: 33px;
}
.gm-hero h1 em{font-style:normal;color:#ffffff}
.gm-hero p.desc{color:rgba(255,255,255,.6);font-size:1rem;max-width:520px;margin-bottom:28px;line-height:1.75}
.hero-stats{display:flex;gap:28px;margin-bottom:28px;flex-wrap:wrap}
.hero-stat{text-align:center}
.hero-stat strong{font-family:var(--font-display);font-size:1.9rem;font-weight:800;color:#fff;display:block}
.hero-stat small{font-size:.88rem;color:rgba(255,255,255,.4);text-transform:uppercase;letter-spacing:.1em}
.hero-btns{display:flex;gap:12px;flex-wrap:wrap}
.hero-btn{
  padding:10px 24px;border-radius:99px;font-size:.95rem;font-weight:600;
  text-decoration:none;display:inline-flex;align-items:center;gap:7px;
  transition:all .2s var(--ease);
}
.hero-btn.primary{background:var(--brand);color:#fff;box-shadow:0 2px 12px var(--brand-glow)}
.hero-btn.primary:hover{background:var(--brand-hover);transform:translateY(-2px);box-shadow:0 6px 20px var(--brand-glow)}
.hero-btn.outline{background:transparent;color:#ffffff;border:1.5px solid rgba(255,255,255,.35)}
.hero-btn.outline:hover{background:rgba(88,64,187,.20);border-color:var(--brand)}
.hero-image{position:relative}
.hero-image .dash-frame{
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);
  border-radius:var(--r-xl);padding:16px;backdrop-filter:blur(8px);
}
.hero-image .dash-frame img{width:100%;border-radius:var(--r-lg);display:block}
.float-tag{
  position:absolute;background:rgba(255,255,255,.12);backdrop-filter:blur(8px);
  border:1px solid rgba(255,255,255,.15);border-radius:var(--r-md);
  padding:8px 14px;display:flex;align-items:center;gap:6px;
  color:#fff;font-size:.92rem;font-weight:600;
  animation:fTag 3s ease-in-out infinite;white-space:nowrap;
}
.float-tag i{font-size:15px;color:#ffffff}
.ft-1{top:-30px;left:-50px;animation-delay:0s;z-index:2}
.ft-2{top:62%;right:-30px;animation-delay:.6s;z-index:2}
.ft-3{bottom:-20px;left:-50px;animation-delay:1.2s;z-index:2}
@keyframes fTag{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}

/* CONTENT AREA */
.gm-content{
  padding:40px 48px 80px;
  max-width:100%;overflow-x:clip;
  box-sizing:border-box;
}

/* DOC SECTIONS */
.doc-section{margin-bottom:48px;scroll-margin-top:80px}
.section-header{display:flex;align-items:center;gap:14px;margin-bottom:20px}
.section-icon{
  width:46px;height:46px;border-radius:var(--r-md);
  background:var(--brand);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
  box-shadow:0 3px 10px var(--brand-glow);
}
.section-icon i{font-size:20px;color:#fff}
.section-header h2{font-family:var(--font-display);font-size:1.35rem;font-weight:700;color:var(--ink);margin-bottom:3px}
.section-subtitle{color:var(--ink-muted);font-size:.95rem;margin:0}

.content-card{
  background:var(--surface);border-radius:var(--r-lg);padding:24px;
  box-shadow:var(--shadow-xs);border:1px solid var(--border);
  margin-bottom:14px;
  overflow:visible;
}

/* Welcome banner */
.welcome-banner{
  background:#8fc0e259;
  border-radius:var(--r-lg);padding:24px 28px;
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:22px;overflow:hidden;position:relative;
}
.welcome-banner::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at right,rgba(88,64,187,.25),transparent 70%)}
.banner-content{position:relative;z-index:1}
.banner-content h3{color:#fff;font-family:var(--font-display);font-weight:700;font-size:1.2rem;margin-bottom:6px}
.banner-content p{color:rgba(255,255,255,.88);margin:0;font-size:1rem}
.banner-icon{font-size:48px;opacity:.2;position:relative;z-index:1;color:#fff}

/* Feature grid */
.feature-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:16px}
.feature-item{
  background:var(--page);border:1px solid var(--border);border-radius:var(--r-md);
  padding:16px;transition:all .2s var(--ease);
}
.feature-item:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);border-color:var(--brand)}
.feature-icon{width:42px;height:42px;border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;margin-bottom:10px}
.feature-icon i{font-size:18px}
.feature-item h4{font-size:1rem;font-weight:700;margin-bottom:4px;color:var(--ink)}
.feature-item p{font-size:.93rem;color:var(--ink-muted);margin:0}
.bg-primary-soft{background:rgba(88,64,187,.08)} .bg-primary-soft i{color:var(--brand)}
.bg-success-soft{background:rgba(13,158,82,.08)} .bg-success-soft i{color:var(--success)}
.bg-warning-soft{background:rgba(217,133,11,.08)} .bg-warning-soft i{color:var(--warning)}
.bg-danger-soft{background:rgba(217,48,37,.08)} .bg-danger-soft i{color:var(--danger)}
.bg-info-soft{background:rgba(88,64,187,.08)} .bg-info-soft i{color:var(--info)}
.bg-purple-soft{background:rgba(124,77,255,.08)} .bg-purple-soft i{color:#7C4DFF}
.bg-teal-soft{background:rgba(0,172,150,.08)} .bg-teal-soft i{color:#00AC96}

/* Info boxes */
.info-box{display:flex;gap:12px;padding:14px 16px;border-radius:var(--r-md);margin-top:14px;align-items:flex-start}
.info-box-primary{background:rgba(88,64,187,.06);border:1px solid rgba(88,64,187,.15)}
.info-box-warning{background:rgba(217,133,11,.06);border:1px solid rgba(217,133,11,.15)}
.info-box-success{background:rgba(13,158,82,.06);border:1px solid rgba(13,158,82,.15)}
.info-box-info{background:rgba(88,64,187,.06);border:1px solid rgba(88,64,187,.15)}
.info-box-danger{background:rgba(217,48,37,.06);border:1px solid rgba(217,48,37,.15)}
.info-icon{flex-shrink:0;margin-top:1px}
.info-icon i{font-size:18px}
.info-box-primary .info-icon i{color:var(--brand)}
.info-box-warning .info-icon i{color:var(--warning)}
.info-box-success .info-icon i{color:var(--success)}
.info-box-info .info-icon i{color:var(--info)}
.info-box-danger .info-icon i{color:var(--danger)}
.info-content h5{font-size:1rem;font-weight:700;margin-bottom:3px;color:var(--ink)}
.info-content p{font-size:.95rem;color:var(--ink-light);margin:0;line-height:1.6}
.info-content code{background:rgba(0,0,0,.06);padding:1px 5px;border-radius:4px;font-family:var(--font-mono);font-size:.93rem}

/* Steps */
.steps-container{margin-top:8px}
.step-item{display:flex;gap:16px;margin-bottom:24px;position:relative}
.step-item::before{content:'';position:absolute;left:18px;top:40px;bottom:-6px;width:2px;background:var(--border)}
.step-item:last-child::before{display:none}
.step-number{
  width:38px;height:38px;border-radius:50%;
  background:var(--brand);
  color:#fff;font-weight:800;font-size:1rem;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
  box-shadow:0 3px 10px var(--brand-glow);
}
.step-content{flex:1}
.step-content h4{font-size:1rem;font-weight:700;margin-bottom:4px;color:var(--ink)}
.step-content p{font-size:.95rem;color:var(--ink-muted);margin:0}
.step-content code{background:rgba(0,0,0,.06);padding:1px 5px;border-radius:4px;font-family:var(--font-mono);font-size:.93rem}
.step-content strong{color:var(--ink)}

/* New: image boxes under installation steps */
.step-img-box{
  background:var(--page);
  border:1px dashed rgba(88,64,187,.35);
  border-radius:var(--r-md);
  overflow:hidden;
  margin-top:10px;
  min-height:170px;
  display:flex;
  align-items:center;
  justify-content:center;
}
.step-img-box .image-placeholder{padding:26px}

/* Requirements */
.requirements-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(155px,1fr));gap:40px;margin-bottom:16px}
.requirement-card{background:var(--page);border:1px solid var(--border);border-radius:var(--r-md);padding:16px;text-align:center;transition:all .2s var(--ease)}
.requirement-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);border-color:var(--brand)}
.req-icon{width:48px;height:48px;background:var(--brand);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 8px}
.req-icon i{font-size:22px;color:#fff}
.req-icon.php{background:#7C4DFF}
.req-icon.mysql{background:var(--brand)}
.req-icon.memory{background:#0D9E52}
.requirement-card h4{font-size:1rem;font-weight:700;margin-bottom:4px;color:var(--ink)}
.version-badge{display:inline-block;background:var(--brand-soft);color:var(--brand);font-size:.88rem;font-weight:600;padding:2px 9px;border-radius:99px;margin-bottom:5px}
.requirement-card p{font-size:.92rem;color:var(--ink-muted);margin:0}

/* Role grid */
.role-grid{display:flex;flex-wrap:wrap;justify-content:space-evenly;gap:14px;margin:16px 0}
.role-card{background:var(--page);border:2px solid var(--border);border-radius:var(--r-md);padding:16px 14px;text-align:center;transition:all .25s var(--ease);flex:0 0 140px;width:140px}
.role-card{background:var(--page);border:1px solid var(--border);border-radius:var(--r-md);padding:14px;text-align:center;transition:all .2s var(--ease)}
.role-card:hover{border-color:var(--brand);transform:translateY(-2px);box-shadow:var(--shadow-md)}
.role-card .ri{font-size:24px;display:block;margin-bottom:6px}
.role-card .rn{font-weight:700;font-size:.95rem;color:var(--ink);margin-bottom:2px}
.role-card .rd{font-size:.88rem;color:var(--ink-muted)}

/* Code blocks */
.code-block-wrap{background:var(--code-bg);border-radius:var(--r-md);overflow:hidden;margin:12px 0}
.code-header{display:flex;align-items:center;justify-content:space-between;padding:8px 14px;background:rgba(255,255,255,.04);border-bottom:1px solid rgba(255,255,255,.06)}
.code-lang{color:rgba(255,255,255,.4);font-size:.88rem;font-family:var(--font-mono)}
.copy-btn-code{background:rgba(88,64,187,.25);color:#ffffff;border:none;border-radius:4px;padding:3px 10px;font-size:.88rem;cursor:pointer;transition:all .15s var(--ease);font-family:var(--font-mono)}
.copy-btn-code:hover{background:var(--brand);color:#fff}
.code-block-wrap pre{padding:12px 14px;color:#E0E4EA;font-family:var(--font-mono);font-size:.95rem;line-height:1.6;overflow-x:auto;margin:0}

/* How-to box */
.how-to-box{background:rgba(88,64,187,.04);border:1px solid rgba(88,64,187,.12);border-radius:var(--r-md);padding:16px 20px;margin-top:16px}
.how-to-box h4{font-size:1rem;font-weight:700;color:var(--ink);margin-bottom:10px;display:flex;align-items:center;gap:7px}
.how-to-box h4 i{color:var(--brand)}
.numbered-steps{padding-left:16px}
.numbered-steps li{margin-bottom:6px;font-size:.95rem;color:var(--ink-light)}
.numbered-steps li strong{color:var(--ink)}

/* Doc images */
.doc-img{display:block;max-width:100%;margin:12px auto;border-radius:var(--r-md);border:1px solid var(--border);background:var(--surface);box-shadow:var(--shadow-xs);transition:all .2s var(--ease);cursor:zoom-in}
.doc-img:hover{box-shadow:var(--shadow-md)}

/* Step image */
.step-image{background:var(--page);border:1px solid var(--border);border-radius:var(--r-md);overflow:hidden;margin-top:10px}
.step-image img{width:100%;height:100%;display:block;object-fit:contain;background:#fff}
.image-placeholder{display:flex;flex-direction:column;align-items:center;gap:7px;padding:36px;color:var(--ink-muted);font-size:.97rem}
.image-placeholder i{font-size:32px;opacity:.3}




/* Image label: bold title + description above each screenshot */
.img-label{
  margin-top:18px;
  margin-bottom:6px;
  font-size:1.0rem;
  color:var(--ink-muted);
  line-height:1.55;
}
.img-label strong{
  color:var(--ink);
  font-weight:700;
}
.success-message{display:flex;align-items:center;gap:9px;background:rgba(13,158,82,.08);border:1px solid rgba(13,158,82,.15);border-radius:var(--r-sm);padding:10px 14px;margin-top:10px;color:var(--success);font-weight:600;font-size:1rem}

/* Installation tabs */
.installation-tabs .nav-pills .nav-link{color:var(--ink-muted);font-weight:600;font-size:1rem;border-radius:99px;padding:7px 18px;transition:all .2s var(--ease)}
.installation-tabs .nav-pills .nav-link.active{background:var(--brand);color:#fff}
.installation-tabs .tab-content{margin-top:18px}

/* FAQ */
.faq-item{border:1px solid var(--border);border-radius:var(--r-md);overflow:hidden;margin-bottom:8px}
.faq-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;cursor:pointer;background:var(--surface);user-select:none;transition:all .15s var(--ease)}
.faq-header:hover{background:rgba(88,64,187,.03)}
.faq-header.open{background:var(--brand-soft)}
.faq-header strong{font-size:1rem;font-weight:700;color:var(--ink)}
.faq-header i{color:var(--ink-muted);font-size:.95rem;transition:transform .2s}
.faq-header.open i{transform:rotate(180deg)}
.faq-body{max-height:0;overflow:hidden;transition:max-height .3s var(--ease)}
.faq-body.open{max-height:500px}
.faq-body-inner{padding:14px 16px;font-size:1rem;color:var(--ink-light);border-top:1px solid var(--border)}

/* Setup Wizard slideshow */
.wizard-intro-banner{background:#8fc0e259;border-radius:var(--r-xl);padding:24px;position:relative;overflow:hidden;margin-bottom:24px;display:flex;align-items:center;gap:16px}
.wizard-intro-banner::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 80% 20%,rgba(255,255,255,.12),transparent 60%)}
.wizard-badge{font-size:2rem;flex-shrink:0;position:relative;z-index:1}
.wizard-intro-text{position:relative;z-index:1}
.wizard-intro-text h3{color:#fff;font-family:var(--font-display);font-weight:700;font-size:1.25rem;margin-bottom:6px}
.wizard-intro-text p{color:rgba(255,255,255,.88);font-size:1rem;margin:0;line-height:1.6}

/* Stepper navigation */
.wizard-stepper{display:flex;align-items:flex-start;justify-content:center;gap:0;margin-bottom:28px;overflow-x:auto;overflow-y:visible;padding:16px 24px 18px;scrollbar-width:thin}
.wizard-stepper::-webkit-scrollbar{height:4px}
.wizard-stepper::-webkit-scrollbar-thumb{background:var(--border);border-radius:99px}
.wstep{display:flex;flex-direction:column;align-items:center;position:relative;flex:1;min-width:61px;max-width:90px;cursor:pointer;user-select:none}
.wstep:not(:last-child)::after{content:'';position:absolute;top:21px;left:calc(50% + 23px);width:calc(100% - 46px);height:2px;background:var(--border);transition:background .4s ease;z-index:0}
.wstep.completed:not(:last-child)::after{background:var(--brand)}
.wstep-circle{width:44px;height:44px;border-radius:50%;border:2.5px solid var(--border);background:var(--surface);display:flex;align-items:center;justify-content:center;font-size:1.1rem;position:relative;z-index:1;transition:all .3s ease;box-shadow:0 2px 8px rgba(0,0,0,.06)}
.wstep:hover .wstep-circle{border-color:var(--brand);transform:scale(1.07);box-shadow:0 4px 14px var(--brand-glow)}
.wstep.active .wstep-circle{background:var(--brand);border-color:transparent;box-shadow:0 4px 18px var(--brand-glow);transform:scale(1.08)}
.wstep.completed .wstep-circle{background:var(--brand);border-color:transparent;box-shadow:0 3px 10px var(--brand-glow)}
.wstep-icon{line-height:1;transition:opacity .2s;color:var(--brand);display:flex;align-items:center;justify-content:center}
.wstep-icon i{font-size:1.15rem;display:block}
.wstep.active .wstep-icon,.wstep.completed .wstep-icon{color:#fff}
.wstep.completed .wstep-icon{display:none}
.wstep.completed .wstep-circle::after{content:'\2713';font-size:1rem;color:#fff;font-weight:900;line-height:1}
.wstep-label{font-size:.60rem;font-weight:600;text-align:center;color:var(--ink-muted);margin-top:7px;line-height:1.25;transition:color .3s ease;padding:0 2px;word-break:break-word;max-width:72px}
.wstep.active .wstep-label{color:var(--brand);font-weight:700}
.wstep.completed .wstep-label{color:var(--ink-light)}

.wizard-slide-panel{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r-xl);overflow:hidden;box-shadow:var(--shadow-md)}
.wizard-slide{display:none}
.wizard-slide.active{display:flex;flex-direction:column}

.wizard-slide-info{display:flex;align-items:center;gap:16px;padding:20px 24px;border-bottom:1px solid var(--border);background:var(--brand-soft)}
.wsi-num{width:48px;height:48px;border-radius:50%;background:var(--brand);display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);font-size:1.1rem;font-weight:700;color:#fff;flex-shrink:0;box-shadow:0 3px 10px var(--brand-glow)}
.wsi-body{flex:1}
.wsi-title{font-size:1.1rem;font-weight:800;color:var(--ink);margin-bottom:3px}
.wsi-desc{font-size:.97rem;color:var(--ink-muted);line-height:1.55}
.wsi-icon{font-size:1.6rem;flex-shrink:0;color:var(--brand)}

.wizard-slide-img{padding:16px;background:var(--page);width:100%}
.wizard-slide-img img{width:100%;height:auto;display:block;border-radius:var(--r-md);border:1px solid var(--border);box-shadow:var(--shadow-sm);object-fit:contain;background:#fff;transition:transform .3s var(--ease);cursor:zoom-in}
.wizard-slide-img .image-placeholder{width:100%;min-height:200px;background:#fff;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:7px;color:var(--ink-muted);font-size:.97rem}
.wizard-slide-img img:hover{transform:scale(1.01);box-shadow:var(--shadow-md)}

.wizard-nav{display:flex;align-items:center;justify-content:space-between;padding:14px 24px;border-top:1px solid var(--border);background:var(--surface);gap:12px}
.wizard-nav-btn{display:inline-flex;align-items:center;gap:8px;background:var(--surface);border:1.5px solid var(--border);border-radius:99px;padding:9px 20px;font-size:.95rem;font-weight:700;color:var(--ink-muted);cursor:pointer;transition:all .2s var(--ease);text-decoration:none}
.wizard-nav-btn:hover{border-color:var(--brand);color:var(--brand);transform:translateY(-1px);box-shadow:0 3px 10px var(--brand-glow)}
.wizard-nav-btn.primary{background:var(--brand);border-color:transparent;color:#fff;box-shadow:0 3px 12px var(--brand-glow)}
.wizard-nav-btn.primary:hover{box-shadow:0 5px 18px var(--brand-glow);transform:translateY(-2px)}
.wizard-progress-dots{display:flex;gap:7px;align-items:center}
.wizard-progress-dots span{width:8px;height:8px;border-radius:50%;background:var(--border);transition:all .25s var(--ease);cursor:pointer}
.wizard-progress-dots span.active{width:24px;border-radius:99px;background:var(--brand)}

/* Done banner */
.wizard-done-banner{background:#8fc0e259;border-radius:var(--r-lg);padding:26px;display:flex;align-items:center;gap:18px;flex-wrap:wrap;box-shadow:var(--shadow-lg);margin-top:24px}
.wizard-done-icon{font-size:2.4rem;flex-shrink:0}
.wizard-done-text{flex:1;min-width:170px}
.wizard-done-text strong{display:block;color:#fff;font-size:1.05rem;font-weight:800;margin-bottom:4px}
.wizard-done-text span{font-size:.97rem;color:#3D4250;line-height:1.6}

/* Access rights grid */
.access-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px;margin:16px 0}
.access-card{background:var(--page);border:1px solid var(--border);border-radius:var(--r-md);padding:16px;text-align:center;transition:all .2s var(--ease)}
.access-card:hover{border-color:var(--brand);transform:translateY(-2px);box-shadow:var(--shadow-md)}
.access-icon{font-size:26px;display:block;margin-bottom:8px}
.access-title{font-weight:700;font-size:.95rem;color:var(--ink);margin-bottom:3px}
.access-desc{font-size:.88rem;color:var(--ink-muted)}

/* Portal features */
.portal-features{display:flex;flex-direction:column;gap:10px;margin-top:12px}
.portal-feature-item{display:flex;gap:12px;align-items:flex-start;padding:12px 14px;background:var(--page);border:1px solid var(--border);border-radius:var(--r-md);transition:all .15s var(--ease)}
.portal-feature-item:hover{border-color:var(--brand)}
.pf-icon{width:36px;height:36px;background:var(--brand);border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.pf-icon i{font-size:16px;color:#fff}
.pf-content h5{font-size:1rem;font-weight:700;margin-bottom:2px;color:var(--ink)}
.pf-content p{font-size:.93rem;color:var(--ink-muted);margin:0}

/* Section heading inside card */
.card-heading{font-family:var(--font-display);font-weight:700;font-size:1.1rem;color:var(--brand);margin:20px 0 10px;padding-bottom:6px;border-bottom:2px solid var(--border-light)}

/* Footer */
.doc-footer{background:var(--brand-soft);border-radius:var(--r-xl);padding:32px;margin-top:32px;text-align:center;position:relative;overflow:hidden}
.doc-footer::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at center,rgba(88,64,187,.08),transparent 70%)}
.footer-brand{display:flex;align-items:center;justify-content:center;gap:8px;margin-bottom:12px;position:relative}
.footer-brand i{font-size:24px;color:var(--brand)}
.footer-brand span{font-family:var(--font-display);font-weight:700;font-size:1.05rem;color:var(--ink)}
.doc-footer p{color:var(--ink-muted);font-size:.95rem;margin-bottom:12px;position:relative}
.footer-links a{color:var(--brand);font-size:.95rem;text-decoration:none;transition:all .15s var(--ease);border:none}
.footer-links a:hover{color:var(--brand-hover)}
.copyright{color:rgba(0, 0, 0, 0.55) !important;font-size:1rem !important}

/* Back to top */
.back-to-top{
  position:fixed;bottom:22px;right:22px;
  width:42px;height:42px;border-radius:50%;
  background:var(--brand);
  color:#fff;border:none;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 3px 12px var(--brand-glow);
  opacity:0;transform:translateY(10px);
  transition:all .3s var(--ease);z-index:8000;
}
.back-to-top.visible{opacity:1;transform:translateY(0)}
.back-to-top:hover{transform:translateY(-2px);box-shadow:0 6px 20px var(--brand-glow)}

/* Lightbox */
#lightbox{display:none;position:fixed;inset:0;background:rgba(0,0,0,.9);z-index:9990;align-items:center;justify-content:center;padding:20px;cursor:zoom-out}
#lightbox.open{display:flex;animation:lbIn .2s both}
@keyframes lbIn{from{opacity:0}to{opacity:1}}
#lightbox img{max-width:92%;max-height:86vh;border-radius:var(--r-lg);box-shadow:0 20px 60px rgba(0,0,0,.5)}
.lb-close{position:fixed;top:16px;right:20px;color:rgba(255,255,255,.6);font-size:24px;cursor:pointer;background:rgba(255,255,255,.08);border:none;border-radius:50%;width:38px;height:38px;display:flex;align-items:center;justify-content:center;transition:all .15s var(--ease)}
.lb-close:hover{background:rgba(255,255,255,.16);color:#fff}

#mob-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:998}
#mob-overlay.show{display:block}

/* Typography */
.gm-content h1{font-family:var(--font-display);font-size:1.9rem;font-weight:800;color:var(--ink);margin-bottom:8px}
.gm-content h2{font-family:var(--font-display);font-size:1.3rem;font-weight:700;color:var(--ink);margin:24px 0 10px}
.gm-content h3{font-family:var(--font-display);font-size:1.3rem;font-weight:700;color:var(--ink);margin:20px 0 8px}
.gm-content h4{font-family:var(--font-display);font-size:1.1rem;font-weight:700;color:var(--ink);margin:16px 0 6px}
.gm-content h5{font-family:var(--font-display);font-size:1.0rem;font-weight:700;color:var(--brand);text-transform:uppercase;letter-spacing:.05em;margin:12px 0 5px}
.gm-content p{color:var(--ink-light);line-height:1.75;margin-bottom:10px}
.gm-content ul:not(.nav-list):not(.numbered-steps):not(.custom-list){padding-left:0;list-style:none}
.gm-content ul:not(.nav-list):not(.numbered-steps):not(.custom-list):not(.nav-pills) > li{...}
.gm-content ul:not(.nav-list):not(.numbered-steps):not(.custom-list):not(.nav-pills) > li::before{content:'›';position:absolute;left:12px;color:var(--brand);font-size:15px;font-weight:700;line-height:1.4}
.gm-content ul:not(.nav-list):not(.numbered-steps):not(.custom-list) > li:hover{border-color:var(--brand)}
.gm-content ol{padding-left:20px}
.gm-content ol li{font-size:1rem;color:var(--ink-light);margin-bottom:6px;line-height:1.7}
.gm-content ol li strong{color:var(--ink)}
.gm-content code{background:rgba(88,64,187,.08);color:var(--brand);padding:1px 5px;border-radius:4px;font-family:var(--font-mono);font-size:.93rem;font-weight:500}
.gm-content a{color:var(--info);text-decoration:none;border-bottom:1px solid rgba(255, 255, 255, 0.25);transition:all .15s var(--ease)}
.gm-content a:hover{color:var(--brand);border-color:var(--brand)}
.gm-content strong{color:var(--ink)}
.gm-content hr{border:none;height:1px;background:var(--border);margin:24px 0}
.gm-content pre{background:var(--code-bg);color:#E0E4EA;padding:14px;border-radius:var(--r-md);font-family:var(--font-mono);font-size:.93rem;overflow-x:auto;margin:10px 0}
section img:not(.hero-img){max-width:100%}

/* Accordion */
.accordion-item{border:1px solid var(--border) !important;margin-bottom:6px;border-radius:var(--r-md) !important;overflow:hidden}
.accordion-button{background:var(--page);color:var(--ink);font-weight:600;font-size:1rem;padding:12px 16px}
.accordion-button:not(.collapsed){background:var(--brand-soft);color:var(--brand);box-shadow:none}
.accordion-button:focus{box-shadow:none}
.accordion-body{font-size:.95rem;color:var(--ink-light);padding:14px 16px}
.accordion-body img{max-width:100%;border-radius:var(--r-md);border:1px solid var(--border);margin-top:8px}

/* Responsive */
@media(max-width:1100px){.gm-nav-links{display:none}}
@media(max-width:992px){
  .gm-mob-toggle{display:flex !important}
  #app{display:block;padding-top:var(--navbar-h)}
  .gm-sidebar{
    position:fixed !important;top:0;left:0;bottom:0;
    width:280px !important;height:100vh !important;
    transform:translateX(-100%);transition:transform .3s var(--ease);
    z-index:999;box-shadow:var(--shadow-xl);background:var(--surface);
  }
  .gm-sidebar.open{transform:translateX(0)}
  .gm-main{width:100%}
  .gm-content{padding:22px 18px 48px}
  .gm-hero .hero-inner{padding:0 20px}
  .hero-image{display:none}
  .wizard-slide-img{padding:10px}
  .wizard-slide-img img{height:auto}
  .wizard-stepper{gap:0;padding:8px 12px 10px;display:-webkit-box}
  .wstep{min-width:52px;max-width:64px}
  .wstep-circle{width:36px;height:36px;font-size:.95rem}
  .wstep:not(:last-child)::after{top:17px;left:calc(50% + 19px);width:calc(100% - 38px)}
  .wstep-label{font-size:.6rem}
  .wizard-slide-info{padding:14px 16px;gap:10px}
  .wsi-icon{display:none}
  .wizard-nav{padding:12px 16px}
}
@media(max-width:600px){
  .gm-hero{padding:40px 0 36px}
  .hero-stats{gap:18px}
  .feature-grid{grid-template-columns:1fr 1fr}
  .requirements-grid{grid-template-columns:1fr 1fr}
  .gm-content{padding:16px 14px 40px}
  .role-grid{grid-template-columns:repeat(2,1fr)}
}

.sec-chip{display:inline-block;background:var(--brand-soft);color:var(--brand);font-size:1rem;font-weight:700;padding:3px 10px;border-radius:99px;margin-bottom:8px;letter-spacing:.02em}


/* Get Support section */
.get-support-section{padding:40px 0 0}
.support-section-header{display:flex;align-items:center;gap:14px;margin-bottom:28px}
.support-icon-box{width:52px;height:52px;border-radius:var(--r-md);background:var(--brand);display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 3px 12px var(--brand-glow)}
.support-icon-box i{font-size:24px;color:#fff}
.support-section-header h2{font-size:1.5rem;font-weight:800;color:var(--ink);margin:0 0 3px}
.support-section-header p{color:var(--ink-muted);font-size:.97rem;margin:0}
.support-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:40px}
.support-card{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r-xl);padding:32px 24px;text-align:center;transition:all .22s var(--ease)}
.support-card:hover{border-color:var(--brand);transform:translateY(-3px);box-shadow:var(--shadow-md)}
.support-card-icon{width:52px;height:52px;border-radius:var(--r-md);background:var(--brand-soft);display:flex;align-items:center;justify-content:center;margin:0 auto 18px;transition:all .22s var(--ease)}
.support-card:hover .support-card-icon{background:var(--brand);box-shadow:0 4px 14px var(--brand-glow)}
.support-card-icon i{font-size:22px;color:var(--brand);transition:color .22s}
.support-card:hover .support-card-icon i{color:#fff}
.support-card h4{font-size:.85rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--brand);margin:0 0 10px}
.support-card p{font-size:.95rem;color:var(--ink-muted);line-height:1.6;margin:0}
.support-card a{color:var(--brand);text-decoration:none;font-weight:600}
.support-card a:hover{text-decoration:underline}
@media(max-width:768px){
  .support-cards{grid-template-columns:1fr}
  .support-section-header{flex-direction:column;align-items:flex-start;gap:10px}
}

/* Always-open Admin View group */
.snav-label-admin{
  display:flex;align-items:center;gap:7px;
  font-size:.85rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;
  color:var(--brand);padding:10px 20px 4px;
  border-top:1px solid var(--border);margin-top:2px;
}
.snav-label-admin i{font-size:1.0rem;opacity:.8;}
.snav-group-admin{margin-bottom:0;}
.snav-admin-links{list-style:none;margin:0;padding:0;}
.snav-admin-links li a.snav-link{
  display:flex;align-items:center;gap:8px;
  padding:5px 20px 5px 22px;margin:0 8px;border-radius:var(--r-sm);
  color:var(--ink-muted);font-size:1.0rem;font-weight:400;
  text-decoration:none;transition:all .15s var(--ease);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.snav-admin-links li a.snav-link i{font-size:1.0rem;opacity:.5;width:16px;text-align:center;flex-shrink:0;}
.snav-admin-links li a.snav-link:hover{color:var(--ink);background:rgba(0,0,0,.04);}
.snav-admin-links li a.snav-link.active{color:var(--brand);background:var(--brand-soft);font-weight:600;}

/* ════════════════════════════════════════
   SCHOOL-SPECIFIC STYLES
   ════════════════════════════════════════ */

/* ── Sub-section header ── */
.sub-section-header { margin-bottom:12px; padding-bottom:10px; border-bottom:2px solid var(--brand-soft); scroll-margin-top:88px }
.sub-section-header h3 { font-family:var(--font-display); font-size:1.1rem; font-weight:700; color:var(--ink); margin:0 }
.sub-section-header .section-subtitle { color:var(--ink-muted); font-size:.88rem; margin-top:3px }

/* ── Info grid + cards ── */
.info-grid {
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(200px,1fr));
  gap:14px;
  margin:16px 0;
}
.info-card {
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--r-md);
  padding:16px;
  transition:all .2s var(--ease);
  display:flex; flex-direction:column;
}
.info-card:hover { transform:translateY(-2px); box-shadow:var(--shadow-md); border-color:var(--brand) }
.ic-icon  { font-size:1.6rem; margin-bottom:8px }
.ic-title { font-size:.95rem; font-weight:700; color:var(--ink); margin-bottom:4px }
.ic-body  { font-size:.88rem; color:var(--ink-muted); line-height:1.6; flex:1 }

/* Info-card images — full width, proper screenshot size */
.info-card img,
.info-grid .info-card img {
  display:block;
  width:100%;
  height:auto;
  min-height:120px;
  margin-top:12px;
  border-radius:var(--r-sm);
  border:1px solid var(--border);
  box-shadow:var(--shadow-xs);
  object-fit:cover;
  object-position:top;
  cursor:zoom-in;
}
/* Info-grids that contain screenshots — use wider columns */
.info-grid.screenshot-grid {
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
}

/* ── Feat grid ── */
.feat-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(160px,1fr)); gap:12px; margin:16px 0 }
.feat-card {
  background:var(--surface); border:1px solid var(--border);
  border-radius:var(--r-md); padding:16px; text-align:center;
  transition:all .2s var(--ease);
}
.feat-card:hover { transform:translateY(-2px); box-shadow:var(--shadow-md); border-color:var(--brand) }
.feat-icon  { font-size:1.8rem; display:block; margin-bottom:8px }
.feat-title { font-size:.92rem; font-weight:700; color:var(--ink); margin-bottom:3px }
.feat-desc  { font-size:.82rem; color:var(--ink-muted); line-height:1.55 }

/* ── Ordered step-list ── */
ol.step-list {
  padding-left:0;
  list-style:none;
  counter-reset:step-counter;
  margin:12px 0 16px;
}
ol.step-list > li {
  counter-increment:step-counter;
  position:relative;
  padding-left:38px;
  margin-bottom:20px;
}
ol.step-list > li::before {
  content:counter(step-counter);
  position:absolute; left:0; top:2px;
  width:24px; height:24px; border-radius:50%;
  background:var(--brand);
  color:#fff; font-size:.75rem; font-weight:700;
  display:flex; align-items:center; justify-content:center;
  line-height:1;
}
ol.step-list > li img {
  display:block;
  width:100%;
  height:auto;
  margin-top:10px;
  border-radius:var(--r-md);
  border:1px solid var(--border);
  box-shadow:var(--shadow-sm);
  clear:both;
  cursor:zoom-in;
}

/* ── Screenshot frame ── */
.screenshot {
  background:var(--surface); border:1px solid var(--border);
  border-radius:var(--r-lg); overflow:hidden;
  box-shadow:var(--shadow-sm); margin:16px 0;
}
.ss-label {
  display:flex; align-items:center; gap:6px;
  padding:10px 14px; background:var(--page); border-bottom:1px solid var(--border);
}
.dot { width:10px; height:10px; border-radius:50% }
.dot.r { background:#FF5F57 }
.dot.y { background:#FFBD2E }
.dot.g { background:#28CA41 }
.ss-label span { font-size:.85rem; color:var(--ink-muted); font-weight:500 }
.screenshot img { width:100%; display:block; cursor:zoom-in }

/* ── Field table ── */
.field-table { width:100%; border-collapse:collapse; margin:16px 0; font-size:.9rem }
.doc-section table, .gm-content table { display:block; overflow-x:auto; -webkit-overflow-scrolling:touch; width:100% }
.doc-section .field-table, .gm-content .field-table { display:table }
.field-table th {
  background:var(--brand); color:#fff; font-weight:700;
  padding:10px 14px; text-align:left;
}
.field-table td { padding:9px 14px; border-bottom:1px solid var(--border); color:var(--ink-light) }
.field-table tr:last-child td { border-bottom:none }
.field-table tr:hover td { background:var(--brand-soft) }

/* ── Shortcode list ── */
.shortcode-list { list-style:none; padding:0; display:flex; flex-wrap:wrap; gap:8px; margin:12px 0 }
.shortcode-list li { background:var(--page); border:1px solid var(--border); border-radius:var(--r-sm); padding:5px 10px; font-size:.88rem; color:var(--ink-light) }
.shortcode-list li code { background:none; padding:0; color:var(--brand); font-weight:600 }

/* ── Callout boxes ── */
.callout {
  display:flex; gap:12px; padding:14px 16px;
  border-radius:var(--r-md); margin:16px 0; align-items:flex-start;
}
.callout.warning { background:rgba(217,133,11,.06); border:1px solid rgba(217,133,11,.2) }
.callout.info    { background:rgba(88,64,187,.06); border:1px solid rgba(88,64,187,.2) }
.callout.success { background:rgba(13,158,82,.06);  border:1px solid rgba(13,158,82,.2) }
.callout-icon { font-size:1.2rem; flex-shrink:0; margin-top:1px }
.callout-body strong { font-size:.95rem; font-weight:700; color:var(--ink); display:block; margin-bottom:3px }
.callout-body p { font-size:.9rem; color:var(--ink-light); margin:0; line-height:1.6 }

/* ── Copy code blocks ── */
.copy-wrap { position:relative; background:var(--code-bg); border-radius:var(--r-md); overflow:hidden; margin:10px 0 }
.copy-bar  { display:flex; align-items:center; justify-content:space-between; padding:8px 14px; border-bottom:1px solid rgba(255,255,255,.08) }
.copy-bar .code-lang { font-family:var(--font-mono); font-size:.82rem; color:rgba(255,255,255,.4) }
.copy-btn {
  background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.12);
  color:rgba(255,255,255,.6); font-size:.8rem; padding:4px 10px;
  border-radius:var(--r-sm); cursor:pointer; transition:all .15s;
}
.copy-btn:hover { background:rgba(255,255,255,.16); color:#fff }
.copy-wrap pre {
  padding:16px 20px; color:#E8EAED;
  font-family:var(--font-mono); font-size:.92rem; line-height:1.7;
  overflow-x:auto; margin:0;
}

/* ── Custom accordion (c-acc) ── */
.c-acc { border:1px solid var(--border); border-radius:var(--r-md); overflow:hidden; margin-bottom:8px }
.c-acc-head {
  display:flex; align-items:center; justify-content:space-between;
  padding:12px 16px; cursor:pointer; background:var(--surface);
  user-select:none; transition:background .15s var(--ease);
}
.c-acc-head:hover { background:rgba(88,64,187,.03) }
.c-acc.open .c-acc-head { background:var(--brand-soft) }
.c-acc-head strong { font-size:.95rem; font-weight:700; color:var(--ink) }
.acc-chev { color:var(--ink-muted); font-size:1.1rem; transition:transform .2s }
.c-acc.open .acc-chev { transform:rotate(90deg) }
.c-acc-body { max-height:0; overflow:hidden; transition:max-height .35s var(--ease) }
.c-acc.open .c-acc-body { max-height:2000px }
.c-acc-body > * { padding:14px 16px }
.c-acc-body p  { font-size:.93rem; color:var(--ink-light); margin-bottom:8px; line-height:1.6 }

/* ── Active parent sidebar state ── */
.snav-dropdown-btn.active-parent { color:var(--brand); font-weight:600 }

/* ── Sidebar click state ── */
#sidebar.snav-clicking .snav-link:not(.active):hover,
#sidebar.snav-clicking .snav-dropdown a:not(.active):hover,
#sidebar.snav-clicking .snav-dropdown-btn:not(.open):hover {
  background:transparent;
}

/* ── Section images ── */
.doc-section > img,
.doc-section section > img,
.doc-section h3 + img,
.doc-section h4 + img,
.doc-section p + img {
  display:block;
  width:100%;
  max-width:100%;
  height:auto;
  margin:12px 0;
  border-radius:var(--r-md);
  border:1px solid var(--border);
  background:var(--surface);
  box-shadow:var(--shadow-xs);
  cursor:zoom-in;
}

/* ── gm-content typography overrides (school-specific p color) ── */
.gm-content p { font-size:.93rem; color:var(--ink-light); line-height:1.75; margin-bottom:10px }
.gm-content h4 {
  font-family:var(--font-display); font-size:.93rem; font-weight:700; color:var(--ink);
  margin:16px 0 8px; display:flex; align-items:center; gap:10px;
  padding-bottom:8px; border-bottom:2px solid var(--border);
}
.gm-content h4::before { content:''; display:inline-block; width:4px; height:1.4em; background:var(--brand); border-radius:4px; flex-shrink:0 }

/* ── Responsive school-specific ── */
@media(max-width:992px){
  .feat-grid        { grid-template-columns:repeat(2,1fr); gap:12px }
  .info-grid        { grid-template-columns:repeat(2,1fr) }
  .shortcode-list   { columns:1 }
  .field-table { font-size:.86rem }
  .field-table th, .field-table td { padding:9px 10px }
}
@media(max-width:768px){
  .feat-grid         { grid-template-columns:1fr 1fr; gap:10px }
  .info-grid         { grid-template-columns:1fr }
  .feat-card  { padding:14px 12px; font-size:.85rem }
  .feat-icon  { font-size:1.4rem }
  .feat-title { font-size:.88rem }
  .feat-desc  { font-size:.78rem }
  .field-table-wrap { overflow-x:auto; -webkit-overflow-scrolling:touch }
  .field-table      { min-width:460px; font-size:.84rem }
  table             { display:block; overflow-x:auto; -webkit-overflow-scrolling:touch }
  .callout { padding:12px 14px; gap:10px }
  .ss-label { font-size:.78rem; padding:6px 10px }
  .shortcode-list li { font-size:.84rem }
  .c-acc-head { padding:14px 16px; font-size:.9rem }
}
@media(max-width:480px){
  .feat-grid         { grid-template-columns:1fr; gap:8px }
  .info-grid         { grid-template-columns:1fr }
  .field-table  { min-width:380px; font-size:.8rem }
  .field-table th, .field-table td { padding:7px 8px }
  .callout { flex-direction:column; gap:8px }
  .feat-card { padding:12px 10px }
}
@media(max-width:360px){
  .field-table { min-width:320px; font-size:.77rem }
}
