:root {
    --primary: #b45309;
    --secondary: #4c1d0b;
    --accent: #f59e0b;
    --background: #f8fafc;
    --surface: #ffffff;
    --surface-strong: rgba(255,255,255,.94);
    --text: #111827;
    --muted: #64748b;
    --line: rgba(148,163,184,.28);
    --soft: #f1f5f9;
    --success: #047857;
    --danger: #b91c1c;
    --warning: #92400e;
    --hero-gradient: linear-gradient(135deg,#fff7ed 0%,#fde68a 42%,#f97316 100%);
    --shadow-sm: 0 8px 22px rgba(15,23,42,.06);
    --shadow-card: 0 20px 58px rgba(15,23,42,.10);
    --shadow-deep: 0 32px 90px rgba(15,23,42,.16);
    --radius-sm: 14px;
    --radius: 22px;
    --radius-lg: 30px;
    --sidebar-width: 296px;
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
    margin: 0;
    min-height: 100vh;
    font-family: Inter, "Noto Sans Devanagari", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    color: var(--text);
    background:
        radial-gradient(circle at 8% 0%, color-mix(in srgb,var(--accent) 18%, transparent) 0 240px, transparent 360px),
        radial-gradient(circle at 92% 12%, color-mix(in srgb,var(--primary) 14%, transparent) 0 260px, transparent 420px),
        linear-gradient(180deg,#fffaf3 0%, var(--background) 34%, #eef2ff 100%);
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
}
body.admin-body { background: linear-gradient(135deg,#f8fafc 0%,#fff7ed 45%,#eef2ff 100%); }
a { color: inherit; text-decoration: none; }
button, input, select, textarea { font: inherit; }
button { cursor: pointer; }
img { max-width: 100%; display: block; }
.container { width: min(1220px, calc(100% - 36px)); margin: 0 auto; }
.hidden, .role-hidden, .admin-role-hidden { display: none !important; }
.muted { color: var(--muted); }
.full, .full-span { grid-column: 1 / -1; }

.topbar {
    position: sticky;
    top: 0;
    z-index: 30;
    background: rgba(255,255,255,.78);
    border-bottom: 1px solid rgba(148,163,184,.24);
    backdrop-filter: blur(22px);
    box-shadow: 0 14px 40px rgba(15,23,42,.04);
}
.nav-inner { min-height: 76px; display: flex; align-items: center; justify-content: space-between; gap: 18px; }
.brand-mark { display: inline-flex; align-items: center; gap: 12px; min-width: max-content; }
.brand-symbol {
    width: 46px; height: 46px; border-radius: 18px; display: grid; place-items: center;
    color: #fff; background: linear-gradient(135deg,var(--primary),var(--secondary));
    font-size: 23px; font-weight: 950; box-shadow: 0 16px 35px color-mix(in srgb,var(--primary) 28%, transparent);
}
.brand-mark strong { display: block; font-size: 18px; letter-spacing: -.035em; }
.brand-mark small { display: block; color: var(--muted); font-size: 12px; margin-top: 2px; font-weight: 750; }
.nav-links { display: flex; align-items: center; gap: 10px; color: #475569; font-size: 14px; font-weight: 850; }
.nav-links a { padding: 10px 13px; border-radius: 999px; }
.nav-links a:hover { color: var(--secondary); background: rgba(255,247,237,.92); }
.nav-actions, .button-row, .auth-bar, .package-actions, .card-actions { display: flex; gap: 10px; align-items: center; flex-wrap: wrap; }
.btn {
    border: 0; border-radius: 999px; padding: 12px 17px; font-weight: 900; letter-spacing: -.01em;
    display: inline-flex; align-items: center; justify-content: center; gap: 8px; line-height: 1;
    transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease, background .18s ease;
}
.btn:hover { transform: translateY(-1px); }
.btn-primary { color: #fff; background: linear-gradient(135deg,var(--primary),var(--secondary)); box-shadow: 0 14px 28px color-mix(in srgb,var(--primary) 23%, transparent); }
.btn-secondary { color: #334155; background: rgba(255,255,255,.92); border: 1px solid var(--line); box-shadow: var(--shadow-sm); }
.btn-ghost { color: #475569; background: transparent; }
.btn-primary:disabled, .btn-secondary:disabled { opacity: .55; cursor: not-allowed; transform: none; }

.hero { padding: clamp(32px,5vw,64px) 0 30px; }
.hero-grid { display: grid; grid-template-columns: minmax(0,1.22fr) minmax(340px,420px); gap: 26px; align-items: stretch; }
.hero-panel, .login-panel, .section, .admin-card, .admin-hero {
    background: var(--surface-strong);
    border: 1px solid rgba(255,255,255,.72);
    box-shadow: var(--shadow-card);
    backdrop-filter: blur(20px);
    border-radius: var(--radius-lg);
}
.hero-panel {
    position: relative; overflow: hidden; padding: clamp(30px,6vw,66px);
    background:
        linear-gradient(120deg, rgba(255,255,255,.94), rgba(255,247,237,.90)),
        var(--hero-gradient);
}
.hero-panel:before { content: ""; position: absolute; inset: -120px -130px auto auto; width: 390px; height: 390px; border-radius: 999px; background: color-mix(in srgb,var(--accent) 26%, transparent); filter: blur(8px); }
.hero-panel:after { content: ""; position: absolute; right: 26px; bottom: 26px; width: min(42%,260px); height: 150px; background: url('/assets/images/teerath-route-art.svg') center/contain no-repeat; opacity: .26; pointer-events: none; }
.eyebrow { display: inline-flex; padding: 8px 12px; border-radius: 999px; background: color-mix(in srgb,var(--accent) 15%, white); color: var(--secondary); font-size: 11px; font-weight: 950; letter-spacing: .1em; text-transform: uppercase; margin-bottom: 15px; }
h1, h2, h3, p { margin-top: 0; }
h1 { position: relative; font-size: clamp(42px,6.5vw,78px); line-height: .94; letter-spacing: -.078em; margin-bottom: 18px; max-width: 900px; }
h2 { font-size: clamp(26px,3.7vw,44px); line-height: 1.06; letter-spacing: -.056em; margin-bottom: 12px; }
h3 { letter-spacing: -.03em; margin-bottom: 8px; }
p { color: var(--muted); line-height: 1.66; }
.hero-subtitle { position: relative; max-width: 720px; font-size: 18px; font-weight: 700; color: #475569; }
.hindi { font-family: "Noto Sans Devanagari", Inter, sans-serif; font-weight: 850; }
.hero-actions { margin: 28px 0 34px; position: relative; }
.metrics { display: grid; grid-template-columns: repeat(3,minmax(0,1fr)); gap: 12px; position: relative; }
.metric { padding: 18px; border-radius: 20px; background: rgba(255,255,255,.76); border: 1px solid rgba(251,191,36,.36); box-shadow: var(--shadow-sm); }
.metric strong { display: block; font-size: 29px; letter-spacing: -.05em; }
.metric span { color: #64748b; font-weight: 800; font-size: 13px; }
.login-panel { padding: 24px; display: grid; gap: 16px; align-content: start; }
.portal-tabs { display: grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap: 8px; padding: 7px; background: rgba(241,245,249,.88); border-radius: 19px; }
.portal-tabs button { border: 0; border-radius: 14px; padding: 11px 9px; font-weight: 900; color: #475569; background: transparent; }
.portal-tabs button.active { color: var(--secondary); background: #fff; box-shadow: 0 8px 20px rgba(15,23,42,.08); }

.form-grid { display: grid; gap: 13px; }
.two-col { grid-template-columns: repeat(2,minmax(0,1fr)); }
.three-col { grid-template-columns: repeat(3,minmax(0,1fr)); }
.field label { display: block; font-size: 11px; color: #64748b; font-weight: 950; text-transform: uppercase; letter-spacing: .08em; margin-bottom: 7px; }
.field input, .field select, .field textarea, textarea {
    width: 100%; border: 1px solid var(--line); border-radius: 15px; padding: 13px 14px;
    background: rgba(255,255,255,.96); color: var(--text); outline: none; min-height: 47px;
    transition: border-color .16s ease, box-shadow .16s ease, background .16s ease;
}
.field input:focus, .field select:focus, .field textarea:focus, textarea:focus { border-color: var(--primary); box-shadow: 0 0 0 4px color-mix(in srgb,var(--primary) 13%, transparent); background: #fff; }
textarea { min-height: 96px; resize: vertical; }
.check-row { display: flex; align-items: center; gap: 9px; font-weight: 800; color: #334155; }
.status-note { border-left: 4px solid color-mix(in srgb,var(--accent) 70%, transparent); border-radius: 16px; background: rgba(255,251,235,.78); padding: 13px 15px; color: #475569; font-size: 13px; line-height: 1.55; }
.status-note.ok { border-left-color: var(--success); background: rgba(236,253,245,.85); color: var(--success); }
.status-note.error { border-left-color: var(--danger); background: rgba(254,242,242,.88); color: var(--danger); }

.section { margin: 28px auto; padding: clamp(24px,4vw,40px); }
.section-head { max-width: 780px; margin-bottom: 23px; }
.split-head { max-width: none; display: flex; align-items: flex-start; justify-content: space-between; gap: 18px; }
.grid-3 { display: grid; grid-template-columns: repeat(3,minmax(0,1fr)); gap: 16px; }
.grid-4 { display: grid; grid-template-columns: repeat(4,minmax(0,1fr)); gap: 14px; }
.card { padding: 21px; border-radius: 23px; background: rgba(255,255,255,.91); border: 1px solid var(--line); box-shadow: var(--shadow-sm); transition: transform .18s ease, box-shadow .18s ease; }
.card:hover { transform: translateY(-2px); box-shadow: var(--shadow-card); }
.card-icon { display: inline-flex; border-radius: 999px; padding: 7px 11px; color: var(--secondary); background: color-mix(in srgb,var(--accent) 18%, white); font-size: 11px; font-weight: 950; text-transform: uppercase; margin-bottom: 12px; letter-spacing: .07em; }
.card small { color: #64748b; font-weight: 800; }
.destination-card { min-height: 198px; display: flex; flex-direction: column; justify-content: space-between; background: linear-gradient(180deg,rgba(255,255,255,.96),rgba(248,250,252,.92)); }
.filter-panel, .config-form, .sub-panel.configuration-panel { border: 1px solid var(--line); border-radius: 24px; background: rgba(255,255,255,.78); padding: 18px; margin: 16px 0 20px; box-shadow: var(--shadow-sm); }
.filter-grid { display: grid; grid-template-columns: repeat(5,minmax(0,1fr)); gap: 12px; }
.detail-panel, .route-highlight { margin-top: 16px; border-radius: 24px; border: 1px solid rgba(251,191,36,.30); background: linear-gradient(135deg,rgba(255,255,255,.96),rgba(255,247,237,.90)); padding: 20px; box-shadow: var(--shadow-sm); }
.step-list { display: grid; gap: 12px; }
.step { display: grid; grid-template-columns: 44px 1fr; gap: 13px; align-items: start; padding: 15px; border-radius: 19px; background: rgba(241,245,249,.86); border: 1px solid rgba(148,163,184,.18); }
.step span { width: 44px; height: 44px; display: grid; place-items: center; border-radius: 16px; background: #fff; color: var(--secondary); font-weight: 950; box-shadow: var(--shadow-sm); }
.step p { margin: 0; font-weight: 800; color: #475569; }
.theme-chip { border: 1px solid var(--line); border-radius: 20px; padding: 13px; display: flex; gap: 12px; align-items: center; background: rgba(255,255,255,.90); box-shadow: var(--shadow-sm); }
.theme-swatch { width: 46px; height: 46px; border-radius: 16px; border: 1px solid rgba(255,255,255,.8); box-shadow: inset 0 0 0 1px rgba(15,23,42,.08); }
.footer { padding: 28px 0 40px; color: #64748b; }
.footer .container { display: flex; justify-content: space-between; gap: 12px; flex-wrap: wrap; }

.admin-layout { display: grid; grid-template-columns: var(--sidebar-width) minmax(0,1fr); min-height: 100vh; }
.sidebar { position: sticky; top: 0; height: 100vh; overflow-y: auto; padding: 22px 18px; background: rgba(255,255,255,.88); border-right: 1px solid var(--line); backdrop-filter: blur(22px); box-shadow: 14px 0 36px rgba(15,23,42,.04); }
.sidebar::-webkit-scrollbar { width: 8px; }
.sidebar::-webkit-scrollbar-thumb { background: rgba(148,163,184,.5); border-radius: 99px; }
.admin-menu { display: grid; gap: 6px; margin-top: 26px; }
.admin-menu a { padding: 11px 13px; border-radius: 15px; color: #475569; font-weight: 900; font-size: 13px; display: flex; align-items: center; gap: 8px; }
.admin-menu a:before { content: ""; width: 7px; height: 7px; border-radius: 999px; background: rgba(148,163,184,.65); }
.admin-menu a.active, .admin-menu a:hover { background: linear-gradient(135deg,rgba(255,247,237,.96),rgba(255,255,255,.92)); color: var(--secondary); box-shadow: var(--shadow-sm); }
.admin-menu a.active:before, .admin-menu a:hover:before { background: var(--primary); }
.admin-menu a.disabled-link { display: none; }
.admin-main { min-width: 0; padding: 28px; max-width: 1520px; width: 100%; }
.admin-hero { display: flex; align-items: center; justify-content: space-between; gap: 18px; margin-bottom: 22px; padding: 26px; }
.admin-hero h1 { font-size: clamp(32px,4.8vw,58px); margin-bottom: 8px; max-width: 980px; }
.admin-card { padding: 24px; margin-bottom: 22px; }
.admin-card-head { display: flex; align-items: center; justify-content: space-between; gap: 14px; margin-bottom: 17px; }
.admin-card-head.compact-head, .compact-head { margin-top: 22px; }
.compact-readiness { background: linear-gradient(135deg,rgba(255,255,255,.96),rgba(248,250,252,.90)); }
.role-layout-note { display: inline-flex; gap: 8px; align-items: center; padding: 8px 12px; border-radius: 999px; background: rgba(15,23,42,.06); color: #334155; font-size: 12px; font-weight: 800; }
.workspace-switcher { display: flex; flex-wrap: wrap; gap: 10px; margin: 12px 0 20px; }
.workspace-switcher button, .workspace-switcher .workspace-pill { border: 1px solid var(--line); background: rgba(255,255,255,.80); border-radius: 999px; padding: 10px 14px; font-weight: 900; color: #334155; }
.workspace-switcher button.active, .workspace-switcher .workspace-pill.active { background: var(--primary); color: #fff; border-color: transparent; }
.table-wrap { overflow: auto; border: 1px solid var(--line); border-radius: 18px; background: rgba(255,255,255,.92); box-shadow: var(--shadow-sm); margin: 14px 0; }
table { width: 100%; border-collapse: collapse; min-width: 780px; background: transparent; }
th, td { padding: 14px; text-align: left; border-bottom: 1px solid rgba(148,163,184,.20); vertical-align: top; }
th { background: rgba(248,250,252,.95); color: #475569; font-size: 11px; text-transform: uppercase; letter-spacing: .08em; font-weight: 950; position: sticky; top: 0; z-index: 1; }
td { color: #334155; font-size: 14px; }
td code, .table-wrap code { color: var(--secondary); font-weight: 900; white-space: normal; word-break: break-word; }
.badge { display: inline-flex; align-items: center; border-radius: 999px; padding: 6px 10px; background: rgba(241,245,249,.94); color: #475569; font-size: 12px; font-weight: 900; }
.login-wall { width: min(500px,calc(100% - 32px)); margin: 70px auto; }
.compact-select { border: 1px solid var(--line); border-radius: 13px; padding: 10px 12px; background: #fff; font-weight: 850; color: #475569; }
.mini-btn, .cms-editor-toolbar button {
    border: 1px solid rgba(148,163,184,.35); background: rgba(255,255,255,.94); color: #334155;
    border-radius: 999px; padding: 8px 11px; margin: 2px; font-size: 12px; font-weight: 900; cursor: pointer;
    transition: transform .16s ease, box-shadow .16s ease, border-color .16s ease;
}
.mini-btn:hover, .cms-editor-toolbar button:hover { transform: translateY(-1px); border-color: var(--primary); color: var(--secondary); box-shadow: 0 8px 20px rgba(15,23,42,.08); }
.mini-btn.danger { color: var(--danger); }
.clean-copy-banner { border-radius: 24px; padding: 18px 20px; background: linear-gradient(135deg, rgba(15,23,42,.92), rgba(124,45,18,.88)); color: white; display: grid; gap: 6px; margin: 20px 0; }
.clean-copy-banner strong { font-size: 18px; }
.cms-body { margin-top: 12px; color: var(--muted); line-height: 1.7; }
.cms-body p { margin: 0 0 10px; }
.compact-stat h3 { font-size: 28px; margin: 6px 0 2px; }
.config-value-cell { max-width: 460px; white-space: pre-wrap; word-break: break-word; color: #334155; }
.theme-admin-card { cursor: pointer; }
.cms-rich-editor { min-height: 180px; border: 1px solid rgba(148,163,184,.34); border-radius: 18px; background: #ffffff; padding: 16px; line-height: 1.7; outline: none; box-shadow: inset 0 1px 0 rgba(15,23,42,.03); }
.cms-rich-editor:focus { border-color: var(--primary); box-shadow: 0 0 0 4px color-mix(in srgb,var(--primary) 12%, transparent); }
.cms-editor-toolbar { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 10px; }

@media (max-width: 1180px) {
    .hero-grid { grid-template-columns: 1fr; }
    .filter-grid, .grid-4 { grid-template-columns: repeat(2,minmax(0,1fr)); }
}
@media (max-width: 980px) {
    .admin-layout { grid-template-columns: 1fr; }
    .sidebar { position: relative; height: auto; max-height: none; }
    .admin-menu { grid-template-columns: repeat(2,minmax(0,1fr)); }
    .grid-3, .metrics, .two-col, .three-col, .filter-grid { grid-template-columns: 1fr; }
    .split-head, .admin-hero, .admin-card-head { flex-direction: column; align-items: flex-start; }
    .nav-links { display: none; }
}
@media (max-width: 620px) {
    .container { width: min(100% - 24px, 1220px); }
    .nav-inner { min-height: 66px; }
    .nav-actions .btn-secondary { display: none; }
    .hero { padding-top: 24px; }
    .hero-panel, .login-panel, .section, .admin-card, .admin-hero { border-radius: 22px; }
    h1 { font-size: 40px; }
    .admin-main { padding: 14px; }
    .admin-menu { grid-template-columns: 1fr; }
    .portal-tabs { grid-template-columns: repeat(2, minmax(0,1fr)); }
}

/* Iteration 42: operational-grade navigation and workflow polish */
.admin-menu { gap: 12px; }
.menu-group { border: 1px solid rgba(148,163,184,.22); border-radius: 20px; background: rgba(255,255,255,.58); box-shadow: 0 12px 28px rgba(15,23,42,.045); overflow: hidden; }
.menu-group-title { width: 100%; border: 0; background: linear-gradient(135deg, rgba(248,250,252,.96), rgba(255,247,237,.74)); color: #334155; padding: 12px 14px; text-align: left; font-size: 11px; font-weight: 950; letter-spacing: .12em; text-transform: uppercase; display: flex; align-items: center; justify-content: space-between; }
.menu-group-title:after { content: "⌄"; font-size: 14px; transition: transform .18s ease; }
.menu-group:not(.open) .menu-group-title:after { transform: rotate(-90deg); }
.menu-group-links { display: grid; gap: 4px; padding: 8px; }
.menu-group:not(.open) .menu-group-links { display: none; }
.admin-menu .menu-group a { border-radius: 13px; padding: 10px 11px; }
.admin-menu .menu-group a:before { width: 6px; height: 6px; }
.admin-shell-summary { display: grid; grid-template-columns: repeat(4,minmax(0,1fr)); gap: 12px; margin: 18px 0 0; }
.admin-shell-summary .card { padding: 16px; border-radius: 20px; background: linear-gradient(180deg, rgba(255,255,255,.95), rgba(248,250,252,.88)); }
.admin-shell-summary .card h3 { font-size: 24px; margin: 4px 0 0; }
.role-home-panel { border-radius: 26px; border: 1px solid rgba(148,163,184,.26); background: linear-gradient(135deg,rgba(255,255,255,.96),rgba(255,247,237,.88)); padding: 20px; box-shadow: var(--shadow-card); margin: 18px 0; }
.role-home-actions { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 14px; }
.role-home-actions a { border: 1px solid var(--line); border-radius: 999px; padding: 10px 14px; background: rgba(255,255,255,.88); font-weight: 900; color: #334155; }
.role-home-actions a:hover { color: var(--secondary); border-color: var(--primary); box-shadow: var(--shadow-sm); }
.workflow-health-row { display: grid; grid-template-columns: repeat(5,minmax(0,1fr)); gap: 12px; margin: 16px 0 6px; }
.workflow-health-row .card { padding: 16px; border-radius: 20px; }
.table-wrap tbody tr:hover td { background: rgba(255,247,237,.42); }
.section, .admin-card { scroll-margin-top: 92px; }
@media (max-width: 1180px) { .admin-shell-summary, .workflow-health-row { grid-template-columns: repeat(2,minmax(0,1fr)); } }
@media (max-width: 620px) { .admin-shell-summary, .workflow-health-row { grid-template-columns: 1fr; } }

/* i43 split-screen module shells */
.module-page { min-height: 100vh; }
.standalone-main { max-width: 1280px; margin: 0 auto; padding: 28px; }
.breadcrumb { display:flex; gap:10px; align-items:center; margin: 0 0 18px; font-size: 0.92rem; color: var(--muted, #64748b); }
.breadcrumb a { color: inherit; text-decoration: none; font-weight: 700; }
.breadcrumb strong { color: var(--text, #0f172a); }
.compact-page-links { display:flex; flex-wrap:wrap; gap:10px; margin-top:12px; }
.compact-page-links a { text-decoration:none; }

/* Iteration 88: low-cost multi-login and admin-managed identity settings */
.auth-provider-panel {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 12px;
    margin: 14px 0;
}
.provider-login-btn {
    border: 1px solid rgba(15, 23, 42, 0.12);
    border-radius: 18px;
    background: linear-gradient(135deg, rgba(255,255,255,0.96), rgba(248,250,252,0.9));
    color: var(--text, #0f172a);
    padding: 12px 14px;
    text-align: left;
    display: flex;
    flex-direction: column;
    gap: 3px;
    box-shadow: 0 14px 34px rgba(15, 23, 42, 0.08);
    cursor: pointer;
}
.provider-login-btn span { font-weight: 800; }
.provider-login-btn small { color: #64748b; }
.provider-login-btn.disabled {
    cursor: not-allowed;
    opacity: 0.68;
    background: rgba(241, 245, 249, 0.92);
}
.auth-option-empty,
.auth-divider {
    color: #64748b;
    font-size: 0.9rem;
    text-align: center;
    margin: 10px 0;
}
.auth-divider {
    display: flex;
    align-items: center;
    gap: 10px;
}
.auth-divider::before,
.auth-divider::after {
    content: "";
    height: 1px;
    flex: 1;
    background: rgba(100, 116, 139, 0.25);
}
.guest-booking-row { margin: 10px 0 4px; }
.guest-booking-row .btn { width: 100%; justify-content: center; }
.dual-provider-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
    gap: 18px;
    margin: 12px 0 18px;
}
.login-provider-config-card h3 { margin-top: 0; }
.login-settings-grid .check-row {
    min-height: 48px;
    border: 1px solid rgba(15, 23, 42, 0.08);
    border-radius: 16px;
    background: rgba(255, 255, 255, 0.78);
    padding: 12px 14px;
}
@media (max-width: 720px) {
    .dual-provider-grid { grid-template-columns: 1fr; }
    .auth-provider-panel { grid-template-columns: 1fr; }
}
