/* ============================================================================
   MAINEMARIJUANA.US - UNIFIED GLASSMORPHIC DESIGN SYSTEM
   Professional cannabis compliance resource platform
   ============================================================================ */

/* CSS CUSTOM PROPERTIES (DESIGN TOKENS) ===================================== */
:root {
  --font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
  --font-mono: "SF Mono", Monaco, Consolas, monospace;
  --transition-base: 0.3s cubic-bezier(0.25, 0.8, 0.25, 1);
  --transition-fast: 0.15s ease-out;
  --space-xs: 0.25rem;
  --space-sm: 0.5rem;
  --space-md: 1rem;
  --space-lg: 1.5rem;
  --space-xl: 2rem;
  --space-2xl: 3rem;
  --radius-sm: 8px;
  --radius-md: 12px;
  --radius-lg: 16px;
  --bg-gradient: linear-gradient(120deg, #89f7fe 0%, #66a6ff 100%);
  --glass-bg: rgba(255, 255, 255, 0.7);
  --glass-bg-strong: rgba(255, 255, 255, 0.85);
  --glass-border: rgba(255, 255, 255, 0.3);
  --glass-shadow: rgba(0, 0, 0, 0.1);
  --text-color: #1a202c;
  --text-muted: #4a5568;
  --text-faint: #718096;
  --accent-primary: #0066cc;
  --accent-primary-hover: #0052a3;
  --accent-success: #10b981;
  --accent-warning: #f59e0b;
  --accent-danger: #ef4444;
  --link-color: #0066cc;
  --link-hover: #0052a3;
  --input-bg: rgba(255, 255, 255, 0.9);
  --input-border: rgba(0, 0, 0, 0.15);
  --input-focus-border: #0066cc;
}

[data-theme="dark"] {
  --bg-gradient: linear-gradient(120deg, #1a202c 0%, #2d3748 100%);
  --glass-bg: rgba(45, 55, 72, 0.7);
  --glass-bg-strong: rgba(45, 55, 72, 0.9);
  --glass-border: rgba(255, 255, 255, 0.1);
  --glass-shadow: rgba(0, 0, 0, 0.3);
  --text-color: #e2e8f0;
  --text-muted: #a0aec0;
  --text-faint: #718096;
  --accent-primary: #4dabf7;
  --accent-primary-hover: #339af0;
  --accent-success: #34d399;
  --accent-warning: #fbbf24;
  --accent-danger: #f87171;
  --link-color: #4dabf7;
  --link-hover: #339af0;
  --input-bg: rgba(26, 32, 44, 0.8);
  --input-border: rgba(255, 255, 255, 0.1);
  --input-focus-border: #4dabf7;
}

/* Medical Program Theme - Green/Teal Palette (Light Mode) */
body[data-program="medical"] {
  --bg-gradient: linear-gradient(120deg, #34d399 0%, #10b981 100%);
  --glass-bg: rgba(255, 255, 255, 0.7);
  --glass-bg-strong: rgba(255, 255, 255, 0.85);
  --glass-border: rgba(255, 255, 255, 0.3);
  --glass-shadow: rgba(0, 0, 0, 0.1);
  --text-color: #064e3b;
  --text-muted: #047857;
  --text-faint: #059669;
  --accent-primary: #059669;
  --accent-primary-hover: #047857;
  --accent-success: #10b981;
  --accent-warning: #f59e0b;
  --accent-danger: #ef4444;
  --link-color: #047857;
  --link-hover: #065f46;
  --input-bg: rgba(255, 255, 255, 0.9);
  --input-border: rgba(0, 0, 0, 0.15);
  --input-focus-border: #059669;
}

/* Medical Program Theme - Dark Mode Override */
html[data-theme="dark"] body[data-program="medical"] {
  --bg-gradient: linear-gradient(120deg, #064e3b 0%, #065f46 100%);
  --glass-bg: rgba(6, 78, 59, 0.7);
  --glass-bg-strong: rgba(6, 78, 59, 0.9);
  --glass-border: rgba(52, 211, 153, 0.2);
  --glass-shadow: rgba(0, 0, 0, 0.3);
  --text-color: #d1fae5;
  --text-muted: #6ee7b7;
  --text-faint: #34d399;
  --accent-primary: #34d399;
  --accent-primary-hover: #6ee7b7;
  --accent-success: #34d399;
  --accent-warning: #fbbf24;
  --accent-danger: #f87171;
  --link-color: #6ee7b7;
  --link-hover: #a7f3d0;
  --input-bg: rgba(6, 78, 59, 0.8);
  --input-border: rgba(52, 211, 153, 0.2);
  --input-focus-border: #34d399;
}

/* BASE RESETS & TYPOGRAPHY ================================================== */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-font-smoothing: antialiased; scroll-behavior: smooth; }
body {
  font-family: var(--font-sans);
  background-image: var(--bg-gradient);
  background-attachment: fixed;
  color: var(--text-color);
  margin: 0;
  padding: var(--space-xl);
  line-height: 1.6;
  min-height: 100vh;
}
@media (max-width: 768px) { body { padding: var(--space-md); } }

h1, h2, h3, h4, h5, h6 { margin-top: 0; margin-bottom: var(--space-md); font-weight: 700; line-height: 1.2; color: var(--text-color); }
h1 { font-size: clamp(1.75rem, 4vw, 2.5rem); margin-bottom: var(--space-lg); }
h2 { font-size: clamp(1.5rem, 3vw, 2rem); margin-top: var(--space-xl); }
h3 { font-size: clamp(1.25rem, 2.5vw, 1.5rem); margin-top: var(--space-lg); }
h4 { font-size: clamp(1.1rem, 2vw, 1.25rem); }
p { margin-top: 0; margin-bottom: var(--space-md); line-height: 1.7; }
a { color: var(--link-color); text-decoration: none; transition: color var(--transition-fast); }
a:hover { color: var(--link-hover); text-decoration: underline; }
strong { font-weight: 600; }
code { font-family: var(--font-mono); font-size: 0.9em; background: var(--glass-bg); padding: 0.125rem 0.375rem; border-radius: var(--radius-sm); }
.text-small { font-size: 0.875rem; }
.text-muted, .muted { color: var(--text-muted); }
.text-faint { color: var(--text-faint); }

/* GLASSMORPHIC COMPONENTS =================================================== */
.glass-panel {
  background: var(--glass-bg);
  -webkit-backdrop-filter: blur(12px);
  backdrop-filter: blur(12px);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-lg);
  padding: var(--space-xl);
  margin-bottom: var(--space-xl);
  box-shadow: 0 8px 32px var(--glass-shadow);
  transition: all var(--transition-base);
}
.glass-panel:hover { transform: translateY(-2px); box-shadow: 0 12px 48px var(--glass-shadow); }
.glass-panel--strong { background: var(--glass-bg-strong); }
@media (max-width: 768px) { .glass-panel { padding: var(--space-lg); margin-bottom: var(--space-lg); } }

/* LAYOUT STRUCTURE ========================================================== */
.site-shell { max-width: 1200px; margin: 0 auto; }
.site-shell.two-column { display: grid; grid-template-columns: 280px 1fr; gap: var(--space-xl); align-items: start; }
@media (max-width: 1024px) { .site-shell.two-column { grid-template-columns: 1fr; } }
.sidebar { position: sticky; top: var(--space-xl); max-height: calc(100vh - 4rem); overflow-y: auto; }
.main-content { min-width: 0; }

header[role="banner"] h1 { margin-bottom: var(--space-sm); }
header[role="banner"] > p { color: var(--text-muted); margin-bottom: var(--space-lg); }
nav[aria-label="Primary"], nav[aria-label="Site"] { display: flex; flex-wrap: wrap; gap: var(--space-md); padding: var(--space-md) 0; }
nav a { padding: var(--space-sm) var(--space-md); background: var(--glass-bg); border: 1px solid var(--glass-border); border-radius: var(--radius-md); transition: all var(--transition-fast); font-weight: 500; }
nav a:hover { background: var(--glass-bg-strong); transform: translateY(-2px); text-decoration: none; }
nav a[aria-current="page"] { background: var(--accent-primary); color: white; border-color: var(--accent-primary); }
[data-theme="dark"] nav a[aria-current="page"] { color: #1a202c; }

.breadcrumbs { margin-bottom: var(--space-lg); }
.breadcrumbs ol { display: flex; flex-wrap: wrap; gap: var(--space-sm); list-style: none; padding: 0; margin: 0; font-size: 0.875rem; color: var(--text-muted); }
.breadcrumbs li:not(:last-child)::after { content: "›"; margin-left: var(--space-sm); color: var(--text-faint); }

/* BUTTONS & INTERACTIVE ELEMENTS ============================================ */
.btn, .btn--primary, .btn--secondary, .btn--ghost, .btn-primary, .btn-secondary, .btn-ghost {
  display: inline-flex; align-items: center; justify-content: center; gap: var(--space-sm);
  padding: var(--space-sm) var(--space-lg); font-family: var(--font-sans); font-size: 1rem; font-weight: 500;
  line-height: 1.5; text-decoration: none; border: 1px solid; border-radius: var(--radius-md);
  cursor: pointer; transition: all var(--transition-fast); white-space: nowrap;
}
.btn--primary, .btn-primary { background: var(--accent-primary); color: white; border-color: var(--accent-primary); }
.btn--primary:hover, .btn-primary:hover { background: var(--accent-primary-hover); border-color: var(--accent-primary-hover); transform: translateY(-2px); box-shadow: 0 4px 12px var(--glass-shadow); text-decoration: none; }
[data-theme="dark"] .btn--primary, [data-theme="dark"] .btn-primary { color: #1a202c; }
.btn--secondary, .btn-secondary { background: var(--glass-bg); color: var(--text-color); border-color: var(--glass-border); }
.btn--secondary:hover, .btn-secondary:hover { background: var(--glass-bg-strong); transform: translateY(-2px); text-decoration: none; }
.btn--ghost, .btn-ghost { background: transparent; color: var(--text-color); border-color: var(--glass-border); }
.btn--ghost:hover, .btn-ghost:hover { background: var(--glass-bg); text-decoration: none; }
button[type="button"]:disabled, .btn:disabled { opacity: 0.5; cursor: not-allowed; }

.hero { text-align: center; padding: var(--space-2xl) var(--space-lg); }
.hero--interior { text-align: left; padding: var(--space-xl) 0; }
.hero__content { max-width: 800px; margin: 0 auto; }
.hero--interior .hero__content { margin: 0; }
.hero__lead { font-size: clamp(1rem, 2vw, 1.25rem); color: var(--text-muted); margin-bottom: var(--space-lg); line-height: 1.6; }
.hero__actions { display: flex; flex-wrap: wrap; gap: var(--space-md); margin-top: var(--space-lg); }
.hero--interior .hero__actions { justify-content: flex-start; }
.hero__note { margin-top: var(--space-lg); font-size: 0.875rem; color: var(--text-faint); }
.status-pill { display: inline-block; padding: var(--space-xs) var(--space-md); background: var(--accent-primary); color: white; border-radius: 999px; font-size: 0.75rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.05em; margin-bottom: var(--space-md); }
[data-theme="dark"] .status-pill { color: #1a202c; }

.resource-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: var(--space-lg); margin: var(--space-xl) 0; }
@media (max-width: 640px) { .resource-grid { grid-template-columns: 1fr; } }
.resource-tile {
  background: var(--glass-bg);
  -webkit-backdrop-filter: blur(12px);
  backdrop-filter: blur(12px);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-lg);
  padding: var(--space-lg);
  transition: all var(--transition-base);
  display: block;
  text-decoration: none;
  color: var(--text-color);
}
.resource-tile:hover { transform: translateY(-4px); box-shadow: 0 12px 48px var(--glass-shadow); text-decoration: none; background: var(--glass-bg-strong); }
.resource-tile h3 { margin-top: 0; margin-bottom: var(--space-sm); color: var(--accent-primary); }
.resource-tile p { margin-bottom: 0; color: var(--text-muted); font-size: 0.9375rem; }

/* FORMS & INPUTS ============================================================ */
input[type="text"], input[type="email"], input[type="number"], input[type="tel"], input[type="search"], select, textarea {
  width: 100%; padding: var(--space-sm) var(--space-md); font-family: var(--font-sans); font-size: 1rem;
  color: var(--text-color); background: var(--input-bg); border: 1px solid var(--input-border);
  border-radius: var(--radius-md); transition: all var(--transition-fast);
}
input:focus, select:focus, textarea:focus { outline: none; border-color: var(--input-focus-border); box-shadow: 0 0 0 3px rgba(66, 153, 225, 0.1); }
label { display: block; margin-bottom: var(--space-sm); font-weight: 500; color: var(--text-color); }
.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0, 0, 0, 0); white-space: nowrap; border-width: 0; }

.calculator-wrapper { max-width: 900px; margin: 0 auto; }
.module { margin-bottom: var(--space-2xl); }
.module__header h2 { margin-top: 0; }
.module__header p { color: var(--text-muted); font-size: 1.0625rem; }
.tool-card {
  background: var(--glass-bg);
  -webkit-backdrop-filter: blur(12px);
  backdrop-filter: blur(12px);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-lg);
  padding: var(--space-xl);
  margin-top: var(--space-lg);
}
.tool-card-header { margin-bottom: var(--space-xl); }
.tool-card-header h3 { margin-top: var(--space-sm); margin-bottom: var(--space-sm); }
.link-meta { display: inline-block; font-size: 0.75rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.05em; color: var(--accent-primary); margin-bottom: var(--space-sm); }

/* CALCULATOR COMPONENTS ===================================================== */
.calc-form { margin-bottom: var(--space-xl); }
.calc-rows { display: flex; flex-direction: column; gap: var(--space-md); margin-bottom: var(--space-lg); }
.calc-row { display: grid; grid-template-columns: 200px 1fr auto; gap: var(--space-md); align-items: center; padding: var(--space-md); background: var(--glass-bg); border: 1px solid var(--glass-border); border-radius: var(--radius-md); }
@media (max-width: 640px) { .calc-row { grid-template-columns: 1fr; } }
.calc-inputs { display: flex; gap: var(--space-sm); }
.calc-remove { width: 36px; height: 36px; display: flex; align-items: center; justify-content: center; background: transparent; border: 1px solid var(--accent-danger); color: var(--accent-danger); border-radius: var(--radius-md); font-size: 1.5rem; cursor: pointer; transition: all var(--transition-fast); }
.calc-remove:hover { background: var(--accent-danger); color: white; }
.calc-actions { display: flex; flex-wrap: wrap; gap: var(--space-md); }

.calc-summary { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: var(--space-lg); padding: var(--space-lg); background: var(--glass-bg-strong); border-radius: var(--radius-md); margin-bottom: var(--space-lg); }
.calc-metric { text-align: center; }
.calc-metric span { display: block; font-size: 0.875rem; color: var(--text-muted); margin-bottom: var(--space-xs); }
.calc-metric strong { display: block; font-size: 1.5rem; font-weight: 700; color: var(--text-color); margin-bottom: var(--space-xs); }
.calc-metric small { display: block; font-size: 0.8125rem; color: var(--text-faint); }

.calc-status { padding: var(--space-md) var(--space-lg); border-radius: var(--radius-md); font-weight: 500; text-align: center; margin-bottom: var(--space-md); }
.calc-status.is-ok { background: rgba(16, 185, 129, 0.1); color: var(--accent-success); border: 1px solid var(--accent-success); }
.calc-status.is-warning { background: rgba(245, 158, 11, 0.1); color: var(--accent-warning); border: 1px solid var(--accent-warning); }
.calc-status.is-error { background: rgba(239, 68, 68, 0.1); color: var(--accent-danger); border: 1px solid var(--accent-danger); }
.calc-footnote { color: var(--text-muted); line-height: 1.6; }
.citation { font-style: italic; }
.citation a { font-weight: 500; }

/* TABLE OF CONTENTS & NAVIGATION ============================================ */
.toc { list-style: none; padding: 0; margin: 0; }
.toc li { margin-bottom: var(--space-sm); }
.toc a { display: block; padding: var(--space-sm) var(--space-md); color: var(--text-muted); border-left: 2px solid transparent; transition: all var(--transition-fast); font-size: 0.9375rem; }
.toc a:hover { color: var(--text-color); background: var(--glass-bg); border-left-color: var(--accent-primary); text-decoration: none; }
.toc a.active { color: var(--accent-primary); background: var(--glass-bg); border-left-color: var(--accent-primary); font-weight: 500; }

/* Theme toggle button - inline nav element for light/dark mode switching */
#theme-toggle {
  background: var(--glass-bg); border: 1px solid var(--glass-border);
  border-radius: var(--radius-md); padding: var(--space-sm) var(--space-md);
  font-size: 1.25rem; cursor: pointer; transition: all var(--transition-fast);
  display: inline-flex; align-items: center; justify-content: center;
}
#theme-toggle:hover {
  background: var(--glass-bg-strong); transform: translateY(-2px);
}
#theme-toggle::before { content: "🌙"; }
[data-theme="dark"] #theme-toggle::before { content: "☀️"; }

footer { text-align: center; padding: var(--space-lg); color: var(--text-muted); font-size: 0.875rem; }


footer { text-align: center; padding: var(--space-lg); color: var(--text-muted); font-size: 0.875rem; }

.skip-link { position: absolute; top: -40px; left: 0; background: var(--accent-primary); color: white; padding: var(--space-sm) var(--space-md); text-decoration: none; border-radius: var(--radius-sm); z-index: 100; }
.skip-link:focus { top: var(--space-sm); left: var(--space-sm); }

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: 0.01ms !important; animation-iteration-count: 1 !important; transition-duration: 0.01ms !important; scroll-behavior: auto !important; }
}

@media print {
  body { background: white; color: black; padding: 0; }
  .glass-panel { background: white; border: 1px solid #ccc; box-shadow: none; page-break-inside: avoid; }
  nav[aria-label="Primary"], nav[aria-label="Site"], .breadcrumbs, .hero__actions, #theme-toggle, .calc-actions, .calc-remove { display: none !important; }
  a { color: black; text-decoration: underline; }
  .calc-summary { border: 2px solid black; }
  h1, h2, h3 { page-break-after: avoid; }
}

@media (max-width: 768px) {
  h1 { font-size: 1.75rem; }
  h2 { font-size: 1.5rem; }
  .hero { padding: var(--space-xl) var(--space-md); }
  .hero__actions { flex-direction: column; align-items: stretch; }
  .hero__actions .btn { width: 100%; }
  .sidebar { position: static; max-height: none; }
}

/* Additional component styles for guide pages */
.toc-nav__title { font-size: 1rem; margin-bottom: var(--space-md); }
.toc-nav__list { list-style: none; padding: 0; margin: 0; }
.toc-nav__list li { margin-bottom: var(--space-sm); }
.toc-nav__list a { display: block; padding: var(--space-sm); color: var(--text-muted); transition: all var(--transition-fast); border-left: 2px solid transparent; }
.toc-nav__list a:hover { color: var(--text-color); background: var(--glass-bg); border-left-color: var(--accent-primary); text-decoration: none; }

.section-intro { margin-bottom: var(--space-xl); }
.section-intro h2 { margin-top: 0; }
.section-stack { margin-bottom: var(--space-2xl); }

.tile-grid { display: grid; gap: var(--space-lg); margin-bottom: var(--space-xl); }
.tile-grid--three { grid-template-columns: repeat(auto-fit, minmax(250px, 1fr)); }
@media (max-width: 768px) { .tile-grid--three { grid-template-columns: 1fr; } }

.tile {
  position: relative;
  background: var(--glass-bg);
  -webkit-backdrop-filter: blur(12px);
  backdrop-filter: blur(12px);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-md);
  padding: var(--space-lg);
  transition: all var(--transition-base);
}
.tile:hover { transform: translateY(-2px); box-shadow: 0 8px 24px var(--glass-shadow); background: var(--glass-bg-strong); }
.tile__link { position: absolute; inset: 0; z-index: 1; }
.tile__label { display: inline-block; font-size: 0.75rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.05em; color: var(--accent-primary); margin-bottom: var(--space-xs); }
.tile h3 { margin-top: var(--space-xs); margin-bottom: var(--space-sm); font-size: 1.125rem; }
.tile p { margin-bottom: 0; color: var(--text-muted); font-size: 0.9375rem; }

.cards { display: grid; gap: var(--space-lg); margin-bottom: var(--space-xl); }
.cards-wide { grid-template-columns: 1fr; }
@media (min-width: 768px) { .cards-wide { grid-template-columns: repeat(2, 1fr); } }

.card {
  background: var(--glass-bg);
  -webkit-backdrop-filter: blur(12px);
  backdrop-filter: blur(12px);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-md);
  padding: var(--space-lg);
}
.card .tagline { display: inline-block; font-size: 0.75rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.05em; color: var(--accent-primary); margin-bottom: var(--space-sm); }
.card h3 { margin-top: var(--space-xs); margin-bottom: var(--space-md); }

.list-plain { list-style: none; padding: 0; margin: 0; }
.list-plain li { margin-bottom: var(--space-sm); line-height: 1.6; }

.data-list { list-style: none; padding: 0; margin: 0; }
.data-list li { margin-bottom: var(--space-md); padding-left: var(--space-md); border-left: 3px solid var(--accent-primary); line-height: 1.7; }
.data-list strong { color: var(--accent-primary); font-weight: 600; }

.site-header { margin-bottom: var(--space-xl); }
.site-header__inner { display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: var(--space-lg); }
.brand { text-decoration: none; display: flex; flex-direction: column; }
.brand__wordmark { font-size: 1.25rem; font-weight: 700; color: var(--text-color); }
.brand__tagline { font-size: 0.875rem; color: var(--text-muted); }
.brand:hover .brand__wordmark { color: var(--accent-primary); }

.nav { display: flex; align-items: center; gap: var(--space-md); flex-wrap: wrap; }
.nav-menu { display: flex; gap: var(--space-md); flex-wrap: wrap; }

.site-shell.single-column { max-width: 1200px; margin: 0 auto; }

.hero--portal { text-align: center; padding: var(--space-2xl) 0; }
.eyebrow { font-size: 0.875rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.05em; color: var(--accent-primary); margin-bottom: var(--space-sm); }

.resource-tile__title { margin-top: 0; margin-bottom: var(--space-sm); color: var(--accent-primary); font-size: 1.25rem; }
.resource-tile__desc { margin-bottom: 0; color: var(--text-muted); }
