@import url("https://fonts.googleapis.com/css2?family=Sarabun:wght@300;400;500;600;700;800&display=swap");

:root{
    --bg:#f4f2fb;
    --bg-soft:#eeeff9;
    --surface:rgba(255,255,255,.66);
    --surface-strong:rgba(255,255,255,.82);
    --surface-2:rgba(255,255,255,.54);
    --glass-dark:rgba(37, 23, 77, .34);
    --text:#241a45;
    --text-soft:#665d86;
    --line:rgba(108, 88, 154, .16);
    --line-strong:rgba(99, 74, 160, .26);
    --primary:#5d33a2;
    --primary-dark:#3d2271;
    --secondary:#1d8a68;
    --secondary-dark:#13634b;
    --accent:#8e6fe0;
    --mint:#7ce0be;
    --danger:#b2384a;
    --warning:#8f6a23;
    --success:#157a59;
    --shadow:0 18px 48px rgba(46, 24, 98, .14);
    --shadow-soft:0 12px 28px rgba(46, 24, 98, .10);
    --shadow-strong:0 24px 60px rgba(33, 18, 73, .22);
    --radius:24px;
    --radius-sm:18px;
    --focus:0 0 0 4px rgba(93, 51, 162, .16);
}

*{box-sizing:border-box}
html,body{margin:0;padding:0;font-family:"Sarabun","Noto Sans Thai","Noto Sans",system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;background:
    radial-gradient(circle at 10% 8%, rgba(93,51,162,.18), transparent 22%),
    radial-gradient(circle at 92% 10%, rgba(29,138,104,.18), transparent 20%),
    radial-gradient(circle at 80% 88%, rgba(142,111,224,.14), transparent 20%),
    linear-gradient(180deg,#f4f2fb 0%, #f8fbff 54%, #f8fffc 100%);
    color:var(--text);
    font-weight:400;
}
body,input,button,select,textarea{font-family:"Sarabun","Noto Sans Thai","Noto Sans",system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif}
body{min-height:100vh;line-height:1.58;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
a{text-decoration:none;color:inherit}
button,input,select,textarea{font:inherit}
img{max-width:100%;display:block}
code{background:rgba(93,51,162,.08);padding:2px 8px;border-radius:999px;color:var(--primary-dark)}

.container{width:min(95%, calc(100% - 32px));margin:0 auto}
.main-layout{padding:24px 0 30px}
.setup-body,.admin-body{background:
    radial-gradient(circle at top left, rgba(93,51,162,.16), transparent 22%),
    radial-gradient(circle at top right, rgba(29,138,104,.18), transparent 26%),
    linear-gradient(180deg,#f3f1fb 0%, #f8fbff 58%, #f8fffc 100%)}

.site-header{
    position:relative;
    overflow:hidden;
    color:#fff;
    padding:28px 0 28px;
    background:
      radial-gradient(circle at 12% 15%, rgba(255,255,255,.12), transparent 20%),
      radial-gradient(circle at 88% 8%, rgba(124,224,190,.18), transparent 22%),
      linear-gradient(135deg, #44226d 0%, #5a33a0 38%, #235a77 70%, #17805e 100%);
    box-shadow:0 18px 44px rgba(38, 20, 82, .24)
}
.site-header::before,
.site-header::after{
    content:"";
    position:absolute;
    border-radius:50%;
    pointer-events:none;
}
.site-header::before{
    right:-80px;top:-80px;width:260px;height:260px;
    background:radial-gradient(circle, rgba(255,255,255,.12) 0%, rgba(255,255,255,0) 72%);
}
.site-header::after{
    left:36%;bottom:-150px;width:360px;height:360px;
    background:radial-gradient(circle, rgba(124,224,190,.14) 0%, rgba(124,224,190,0) 70%);
}
.topbar{
    position:relative;
    z-index:1;
    display:flex;
    justify-content:space-between;
    gap:20px;
    align-items:flex-start;
}
.brand-lockup{
    display:flex;
    gap:18px;
    align-items:flex-start;
    max-width:860px;
}
.brand-logo-group{display:flex;align-items:center;gap:14px;flex-shrink:0}
.brand-logo,
.brand-system-logo{
    background:rgba(255,255,255,.72);
    border:1px solid rgba(255,255,255,.35);
    box-shadow:0 18px 36px rgba(17,13,45,.22);
    backdrop-filter:blur(18px) saturate(160%);
    -webkit-backdrop-filter:blur(18px) saturate(160%);
}
.brand-logo{width:84px;height:84px;object-fit:contain;border-radius:24px;padding:10px}
.brand-system-logo{height:84px;min-width:220px;object-fit:contain;border-radius:24px;padding:8px 12px}
.brand-copy h1,.admin-header h1{margin:6px 0 8px;font-size:clamp(1.78rem,3vw,2.6rem);line-height:1.06}
.subtitle{margin:0;max-width:780px;color:rgba(255,255,255,.92);font-size:1.02rem}
.eyebrow{
    letter-spacing:.12em;
    text-transform:uppercase;
    font-size:.78rem;
    font-weight:800;
    color:#977de6;
}
.site-header .eyebrow,.admin-header .eyebrow,.sidebar-brand .eyebrow{color:#e1d9ff}

.quick-badges,.topbar-actions,.action-row,.header-badges,.detail-code,.footer-inner{
    display:flex;gap:10px;align-items:center;flex-wrap:wrap
}
.quick-badge,.badge,.file-badge,.code-pill,.status-pill{
    display:inline-flex;align-items:center;justify-content:center;
    min-height:32px;padding:6px 13px;border-radius:999px;font-size:.86rem;font-weight:700
}
.quick-badge{
    background:rgba(255,255,255,.10);
    color:#fff;
    border:1px solid rgba(255,255,255,.16);
    backdrop-filter:blur(12px) saturate(150%);
    -webkit-backdrop-filter:blur(12px) saturate(150%);
    box-shadow:inset 0 1px 0 rgba(255,255,255,.14)
}
.badge{background:rgba(93,51,162,.08);color:#4c2b85;border:1px solid rgba(93,51,162,.14)}
.code-pill{background:rgba(93,51,162,.08);color:var(--primary)}
.file-badge{background:rgba(29,138,104,.08);color:#275e4b;border:1px solid rgba(29,138,104,.16)}
.status-pill.published{background:rgba(21,122,89,.10);color:var(--success)}
.status-pill.draft{background:rgba(143,106,35,.10);color:var(--warning)}
.status-pill{background:rgba(93,51,162,.08);color:#4a6280}

.btn{
    display:inline-flex;align-items:center;justify-content:center;gap:8px;
    min-height:48px;padding:11px 18px;border-radius:17px;border:1px solid rgba(255,255,255,.26);
    background:rgba(255,255,255,.66);cursor:pointer;color:var(--text);font-weight:700;
    box-shadow:var(--shadow-soft);
    backdrop-filter:blur(14px) saturate(155%);
    -webkit-backdrop-filter:blur(14px) saturate(155%);
    transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease, background .18s ease
}
.btn:hover{transform:translateY(-2px);border-color:rgba(93,51,162,.22);box-shadow:0 16px 32px rgba(34,18,75,.14)}
.btn:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible,.nav-link:focus-visible{
    outline:none;box-shadow:var(--focus)
}
.btn.primary{
    background:linear-gradient(135deg, rgba(93,51,162,.92) 0%, rgba(122,88,214,.90) 55%, rgba(29,138,104,.86) 100%);
    color:#fff;border-color:rgba(255,255,255,.18)
}
.btn.primary:hover{box-shadow:0 18px 34px rgba(93,51,162,.26)}
.btn.ghost{
    background:rgba(255,255,255,.10);
    border-color:rgba(255,255,255,.18);
    color:#fff;
    backdrop-filter:blur(14px) saturate(155%);
    -webkit-backdrop-filter:blur(14px) saturate(155%)
}
.btn.ghost:hover{background:rgba(255,255,255,.16)}
.btn.danger{background:rgba(255,245,247,.82);border-color:rgba(178,56,74,.20);color:var(--danger)}

.hero-grid,.two-col,.grid-2{display:grid;gap:18px}
.hero-grid{grid-template-columns:minmax(0,1.7fr) minmax(300px,.9fr);margin-bottom:18px}
.hero-grid-wide{grid-template-columns:minmax(0,1.7fr) minmax(320px,.8fr)}
.two-col{grid-template-columns:minmax(0,1.2fr) minmax(300px,.8fr)}
.two-col-40{grid-template-columns:minmax(0,1.4fr) minmax(320px,.8fr)}
.grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}
.stats-stack,.admin-stats-grid,.notice-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.category-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px}
.list-stack,.attachment-list{display:grid;gap:12px}

.hero-card,.content-card,.empty-state,.setup-card,.stat-card,.notice-box,.admin-header,.admin-sidebar,.admin-tab,.list-item,.audit-item,.feedback-item,.list-item-card{
    background:var(--surface);
    border:1px solid rgba(255,255,255,.36);
    border-radius:var(--radius);
    box-shadow:var(--shadow);
    backdrop-filter:blur(18px) saturate(160%);
    -webkit-backdrop-filter:blur(18px) saturate(160%);
}
.hero-card,.content-card,.empty-state,.setup-card,.admin-header,.admin-tab{padding:24px}
.hero-card{
    position:relative;overflow:hidden;
    background:
      linear-gradient(135deg, rgba(255,255,255,.74) 0%, rgba(255,255,255,.58) 100%),
      radial-gradient(circle at top right, rgba(93,51,162,.10), transparent 30%),
      radial-gradient(circle at bottom left, rgba(29,138,104,.08), transparent 28%);
}
.hero-card::after{
    content:"";position:absolute;right:-40px;top:-40px;width:170px;height:170px;border-radius:50%;
    background:radial-gradient(circle, rgba(142,111,224,.18), transparent 72%)
}
.hero-card::before{
    content:"";position:absolute;left:-70px;bottom:-90px;width:220px;height:220px;border-radius:50%;
    background:radial-gradient(circle, rgba(124,224,190,.16), transparent 70%)
}
.hero-card h2{margin:6px 0 12px;font-size:clamp(1.5rem,2.4vw,2.2rem)}
.hero-card p,.detail-description,.detail-details{margin:0;color:var(--text-soft);line-height:1.74}
.hero-brand-row{display:flex;gap:16px;align-items:center;margin-bottom:12px}
.hero-system-logo{
    width:156px;min-width:156px;border-radius:24px;padding:10px 14px;
    background:rgba(255,255,255,.62);border:1px solid rgba(255,255,255,.34);
    box-shadow:var(--shadow-soft)
}

.section-block{margin-bottom:18px}
.section-head{display:flex;justify-content:space-between;gap:16px;align-items:flex-end;margin-bottom:16px}
.section-head.tight{margin-bottom:12px}
.section-head h3,.detail-title,.sidebar-brand h2{margin:2px 0 0;font-size:1.28rem}
.section-note,.list-meta,.detail-meta,.file-meta,.small-text,.items-meta,.stat-sub,.mini-note{
    color:var(--text-soft);font-size:.94rem
}
.notice-banner,.feature-list{display:grid;gap:12px}
.year-meta-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}
.year-meta-item{
    padding:16px 18px;border-radius:20px;min-height:92px;
    background:linear-gradient(180deg, rgba(255,255,255,.62), rgba(255,255,255,.40));
    border:1px solid rgba(255,255,255,.44);
    box-shadow:0 14px 32px rgba(42,34,78,.08), inset 0 1px 0 rgba(255,255,255,.56);
    backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px)
}
.year-meta-label{display:block;font-size:.82rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-soft);margin-bottom:8px}
.year-meta-value{display:block;font-size:1.04rem;line-height:1.55;font-weight:700;color:var(--text)}
.year-meta-item.wide{grid-column:span 2}
.feature-item{
    padding:14px 16px;border-radius:18px;border:1px solid rgba(255,255,255,.36);
    background:rgba(255,255,255,.54);
    box-shadow:inset 0 1px 0 rgba(255,255,255,.42)
}
.notice-box,.inline-tip,.mini-note{
    padding:14px 16px;background:rgba(255,255,255,.46);border:1px solid rgba(255,255,255,.34);border-radius:18px
}
.inline-tip{
    margin-top:16px;
    background:linear-gradient(135deg, rgba(93,51,162,.10), rgba(29,138,104,.08));
    color:#564c75
}

.search-toolbar,.feedback-form,.field,.repeater-grid,.repeater-rows,.checklist-grid,.metric-grid{display:flex;gap:12px;flex-wrap:wrap}
.search-toolbar-stacked > *{flex:1 1 210px}
.feedback-form,.field,.repeater-grid,.repeater-rows,.checklist-grid{display:grid}
.feedback-form{gap:14px}
.compact-form{gap:12px}
.form-grid,.locked-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.field{gap:7px}
.field-span-2{grid-column:span 2}
.field label{font-weight:700;color:#2f4b6e}
.field.checkbox-field{display:flex;align-items:center;gap:10px}
.search-toolbar input,.search-toolbar select,.field input,.field select,.field textarea{
    width:100%;border:1px solid var(--line);border-radius:16px;padding:13px 14px;
    background:rgba(255,255,255,.60);color:var(--text);transition:border-color .18s ease, box-shadow .18s ease, background .18s ease;
    backdrop-filter:blur(12px) saturate(145%);
    -webkit-backdrop-filter:blur(12px) saturate(145%)
}
.search-toolbar input::placeholder,.field input::placeholder,.field textarea::placeholder{color:#8b80ab}
.search-toolbar input:focus,.search-toolbar select:focus,.field input:focus,.field select:focus,.field textarea:focus{
    border-color:rgba(93,51,162,.28);background:rgba(255,255,255,.84)
}
textarea{resize:vertical;min-height:120px}
.form-status{font-size:.95rem;color:var(--text-soft)}
.form-status.success{color:var(--success)}
.form-status.error{color:var(--danger)}

.stat-card{
    position:relative;overflow:hidden;padding:20px;
    background:linear-gradient(135deg, rgba(255,255,255,.66), rgba(255,255,255,.48));
}
.stat-card::before{
    content:"";position:absolute;inset:0 auto 0 0;width:5px;border-radius:999px;
    background:linear-gradient(180deg,var(--primary),var(--secondary))
}
.stat-card::after{
    content:"";position:absolute;right:-34px;bottom:-36px;width:110px;height:110px;border-radius:50%;
    background:radial-gradient(circle, rgba(142,111,224,.14), transparent 72%)
}
.stat-label{font-size:.92rem;color:var(--text-soft)}
.stat-value{font-size:2rem;font-weight:800;margin:8px 0;color:var(--primary-dark)}
.shimmer{
    min-height:120px;
    background:linear-gradient(90deg,rgba(239,233,250,.90) 25%, rgba(255,255,255,.80) 50%, rgba(235,249,243,.88) 75%);
    background-size:200% 100%;
    animation:shimmer 1.4s infinite
}
@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}

.category-card,.metric-box{
    background:linear-gradient(135deg, rgba(255,255,255,.72), rgba(255,255,255,.52));
    border:1px solid rgba(255,255,255,.36);border-radius:20px;padding:18px;cursor:pointer;
    transition:transform .18s ease, border-color .18s ease, box-shadow .18s ease;
    box-shadow:0 12px 28px rgba(45, 25, 94, .10)
}
.category-card:hover,.category-card.active,.metric-box:hover{
    transform:translateY(-3px);border-color:rgba(93,51,162,.24);box-shadow:0 20px 36px rgba(45, 25, 94, .16)
}
.category-card h4,.list-title{margin:8px 0 6px;font-size:1.06rem;font-weight:800}
.category-card p,.small-text{margin:0;color:var(--text-soft);line-height:1.55}
.metric-row,.detail-meta{display:flex;justify-content:space-between;gap:10px;flex-wrap:wrap}
.metric-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
.metric-grid.compact-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
.metric-box{padding:14px 16px;cursor:default}

.table-wrap{
    overflow:auto;border:1px solid rgba(255,255,255,.38);border-radius:18px;background:rgba(255,255,255,.54);
    backdrop-filter:blur(16px) saturate(150%);
    -webkit-backdrop-filter:blur(16px) saturate(150%)
}
.data-table{width:100%;border-collapse:separate;border-spacing:0;background:transparent}
.data-table thead th{
    position:sticky;top:0;z-index:1;
    background:linear-gradient(180deg, rgba(237,231,252,.94), rgba(240,249,246,.90));color:#3a2f60;font-weight:800;font-size:.93rem;
    padding:13px 14px;text-align:left;border-bottom:1px solid rgba(108,88,154,.10)
}
.data-table tbody td{padding:13px 14px;border-bottom:1px solid rgba(108,88,154,.08);vertical-align:top}
.data-table tbody tr:last-child td{border-bottom:0}
.data-table tbody tr{cursor:pointer;transition:background .14s ease}
.data-table tbody tr:hover{background:rgba(255,255,255,.42)}
.compact-table thead th,.compact-table tbody td{padding:10px 12px}
.td-empty{text-align:center;color:var(--text-soft)}
.button-like{cursor:pointer}

.sticky-card{position:sticky;top:18px;align-self:start}
.detail-panel,.structured-public,.rating-box{display:grid;gap:14px}
.attachment-item,.list-item,.audit-item,.feedback-item,.list-item-card{
    border:1px solid rgba(255,255,255,.34);background:linear-gradient(135deg, rgba(255,255,255,.68), rgba(255,255,255,.54));
    border-radius:18px;padding:14px 16px;display:flex;justify-content:space-between;gap:10px;align-items:center;flex-wrap:wrap;
    box-shadow:var(--shadow-soft)
}
.list-item-card.muted-card{opacity:.82}
.rating-box{
    padding:16px 18px;border-radius:20px;border:1px solid rgba(255,255,255,.36);background:rgba(255,255,255,.50)
}
.empty-state,.empty-box{
    padding:22px;border:1px dashed rgba(93,51,162,.22);border-radius:18px;background:rgba(255,255,255,.44);color:var(--text-soft);text-align:center
}
.soft-line{border:0;border-top:1px solid rgba(108,88,154,.10);margin:18px 0}
.audit-item,.feedback-item{display:grid;align-items:start}
.admin-items-layout{align-items:start}
.admin-table-wrap{max-height:700px}
.attachment-editor .attachment-item{background:rgba(255,255,255,.66)}

.setup-wrap{
    min-height:100vh;display:grid;place-items:center;padding:24px
}
.setup-card{width:min(780px,100%)}
.panel-brand{
    display:flex;align-items:center;gap:14px;margin-bottom:12px;flex-wrap:wrap
}
.panel-brand .brand-logo{width:70px;height:70px;border-radius:20px}
.panel-brand .brand-system-logo{height:70px;min-width:200px;border-radius:20px}

.alert{
    padding:14px 16px;border-radius:16px;margin:16px 0;border:1px solid transparent
}
.alert.success{background:rgba(237,249,241,.82);color:var(--success);border-color:rgba(21,122,89,.16)}
.alert.danger,.alert.error{background:rgba(255,244,244,.84);color:var(--danger);border-color:rgba(178,56,74,.16)}

.admin-shell{display:grid;grid-template-columns:310px minmax(0,1fr);min-height:100vh}
.admin-sidebar{
    background:
      radial-gradient(circle at top left, rgba(255,255,255,.12), transparent 20%),
      radial-gradient(circle at bottom right, rgba(124,224,190,.14), transparent 22%),
      linear-gradient(180deg, rgba(52,27,104,.94) 0%, rgba(72,35,116,.94) 48%, rgba(21,108,80,.94) 100%);
    color:#fff;padding:24px 18px;display:flex;flex-direction:column;gap:22px;border-radius:0;
    border-right:1px solid rgba(255,255,255,.10)
}
.sidebar-panel-brand{margin-bottom:10px}
.sidebar-logo{width:62px;height:62px;border-radius:18px}
.sidebar-system-logo{height:62px;min-width:170px;border-radius:18px}
.sidebar-user{color:rgba(255,255,255,.82)}
.sidebar-nav{display:grid;gap:8px}
.nav-link{
    width:100%;text-align:left;padding:12px 14px;border:1px solid rgba(255,255,255,.12);
    background:rgba(255,255,255,.08);color:#fff;border-radius:15px;cursor:pointer;
    backdrop-filter:blur(12px) saturate(150%);
    -webkit-backdrop-filter:blur(12px) saturate(150%);
    transition:background .16s ease, transform .16s ease, border-color .16s ease
}
.nav-link.active,.nav-link:hover{
    background:rgba(255,255,255,.16);
    border-color:rgba(255,255,255,.22);
    transform:translateX(2px)
}
.sidebar-actions{display:grid;gap:10px;margin-top:auto}
.admin-main{padding:24px}
.admin-header{
    display:flex;justify-content:space-between;gap:16px;align-items:flex-start;margin-bottom:18px;
    background:
      linear-gradient(135deg, rgba(255,255,255,.78), rgba(255,255,255,.58)),
      radial-gradient(circle at top right, rgba(124,224,190,.18), transparent 24%),
      radial-gradient(circle at bottom left, rgba(142,111,224,.14), transparent 26%)
}
.admin-tab{display:none}
.admin-tab.active{display:block}

.site-footer{padding:20px 0 28px;color:var(--text-soft)}
.footer-inner{
    justify-content:space-between;padding:14px 0;border-top:1px solid rgba(255,255,255,.40)
}

.repeater-grid,.repeater-rows,.checklist-grid{gap:12px}
.repeater-row,.checklist-item{
    display:grid;gap:12px;padding:14px;border:1px solid rgba(255,255,255,.34);background:rgba(255,255,255,.52);border-radius:18px
}
.monthly-table-field{overflow:auto}
.rating-form{display:grid;gap:12px}
.locked-form-mount{display:grid;gap:16px}
.notice-grid{margin:18px 0}
.notice-box{padding:16px}
.inline-status{margin-top:10px}

.content-card,
.admin-tab,
.setup-card,
.hero-card,
.admin-header,
.stat-card,
.notice-box,
.list-item,
.audit-item,
.feedback-item,
.list-item-card,
.category-card,
.metric-box,
.table-wrap,
.inline-tip,
.mini-note,
.feature-item,
.rating-box,
.empty-box,
.empty-state{
    position:relative;
}
.content-card::after,
.admin-tab::after,
.setup-card::after,
.admin-header::after,
.notice-box::after,
.list-item::after,
.audit-item::after,
.feedback-item::after,
.list-item-card::after,
.category-card::after,
.metric-box::after,
.table-wrap::after,
.feature-item::after,
.rating-box::after,
.empty-box::after,
.empty-state::after{
    content:"";
    position:absolute;
    inset:0;
    border-radius:inherit;
    pointer-events:none;
    box-shadow:inset 0 1px 0 rgba(255,255,255,.34);
}
.brand-copy{display:grid;gap:8px}
.brand-logo{box-shadow:0 16px 36px rgba(35, 19, 75, .18)}
.hero-card h2{max-width:900px}
.hero-brand-row-simple{align-items:flex-start;margin-bottom:8px}
.panel-brand-simple{justify-content:flex-start}

@media (max-width: 1180px){
    .hero-grid,.two-col,.grid-2,.admin-items-layout,.admin-shell{grid-template-columns:1fr}
    .sticky-card{position:static}
    .admin-sidebar{border-radius:0 0 26px 26px}
    .sidebar-nav{display:flex;overflow:auto;padding-bottom:4px}
    .nav-link{white-space:nowrap;min-width:max-content}
}

/* Desktop / large screen layout */
@media (min-width: 1024px){
    .site-header .container{
        width: 95%;
        max-width: 95%;
        margin-left: auto;
        margin-right: auto;
    }

    main.container.main-layout{
        width: 95%;
        max-width: 95%;
        margin-left: auto;
        margin-right: auto;
    }

    .topbar{
        display: grid;
        grid-template-columns: minmax(0, 1.45fr) auto;
        align-items: start;
        column-gap: 28px;
        row-gap: 18px;
    }

    .brand{
        display: grid;
        grid-template-columns: 88px minmax(0, 1fr);
        align-items: start;
        column-gap: 18px;
    }

    .brand-mark{
        width: 88px;
        min-width: 88px;
        height: 88px;
        display: flex;
        align-items: center;
        justify-content: center;
    }

    .brand-copy{
        width: 100%;
        max-width: none;
    }

    .brand-copy .eyebrow{
        display: block;
        width: 100%;
        max-width: none;
        font-size: 0.92rem;
        line-height: 1.35;
        letter-spacing: 0.14em;
        margin-bottom: 10px;
        word-break: break-word;
    }

    .brand-copy h1{
        width: 100%;
        max-width: none;
        font-size: 36px;
        line-height: 1.08;
        letter-spacing: -0.02em;
        margin: 0 0 14px;
        word-break: break-word;
    }

    .brand-copy .subtitle{
        width: 100%;
        max-width: 1100px;
        font-size: 1.18rem;
        line-height: 1.75;
        margin: 0 0 16px;
    }

    .hero-badges{
        display: flex;
        flex-wrap: wrap;
        gap: 10px;
        margin-top: 10px;
    }

    .hero-actions{
        display: flex;
        flex-wrap: wrap;
        justify-content: flex-end;
        align-items: flex-start;
        gap: 12px;
        width: auto;
        max-width: 420px;
        margin-left: auto;
    }

    .hero-actions .btn,
    .hero-actions a.btn,
    .hero-actions button{
        min-width: 150px;
        justify-content: center;
    }

    .overview-grid{
        display: grid;
        grid-template-columns: minmax(0, 1.9fr) minmax(320px, 0.9fr);
        gap: 18px;
        align-items: stretch;
    }

    .stats-grid{
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 16px;
    }

    .search-row{
        display: grid;
        grid-template-columns: 1fr 1fr 1.1fr 280px;
        gap: 12px;
        align-items: center;
    }

    .year-meta{
        display: grid;
        grid-template-columns: 1.8fr 1fr 1fr 1fr;
        gap: 14px;
        margin-bottom: 22px;
    }

    .year-meta-item{
        min-height: 106px;
        display: flex;
        flex-direction: column;
        justify-content: center;
    }

    .group-cards{
        display: grid;
        grid-template-columns: repeat(5, minmax(0, 1fr));
        gap: 16px;
        align-items: stretch;
    }

    .group-card{
        height: 100%;
        display: flex;
        flex-direction: column;
    }

    .group-card .metric-row{
        margin-top: auto;
        padding-top: 14px;
    }

    .detail-layout,
    .detail-container,
    .content-wrap{
        width: 100%;
        max-width: 100%;
    }
}

/* Tablet */
@media (min-width: 768px) and (max-width: 1023.98px){
    .site-header .container,
    main.container.main-layout{
        width: calc(100% - 28px);
        max-width: calc(100% - 28px);
        margin-left: auto;
        margin-right: auto;
    }

    .topbar{
        display: grid;
        grid-template-columns: 1fr;
        gap: 18px;
    }

    .brand{
        display: grid;
        grid-template-columns: 76px minmax(0, 1fr);
        gap: 16px;
        align-items: start;
    }

    .brand-mark{
        width: 76px;
        min-width: 76px;
        height: 76px;
    }

    .brand-copy h1{
        font-size: clamp(2rem, 4.6vw, 3rem);
        line-height: 1.12;
    }

    .brand-copy .subtitle{
        font-size: 1.05rem;
        line-height: 1.65;
        max-width: none;
    }

    .hero-actions{
        display: flex;
        flex-wrap: wrap;
        gap: 10px;
        justify-content: flex-start;
    }

    .overview-grid{
        grid-template-columns: 1fr;
    }

    .stats-grid{
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 14px;
    }

    .search-row{
        grid-template-columns: 1fr 1fr;
        gap: 12px;
    }

    .search-row .search-input,
    .search-row .search-btn{
        grid-column: span 2;
    }

    .year-meta{
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 14px;
    }

    .group-cards{
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 14px;
    }
}

/* Mobile */
@media (max-width: 767.98px){
    .site-header .container,
    main.container.main-layout{
        width: calc(100% - 20px);
        max-width: calc(100% - 20px);
        margin-left: auto;
        margin-right: auto;
    }

    .topbar{
        display: grid;
        grid-template-columns: 1fr;
        gap: 16px;
    }

    .brand{
        display: grid;
        grid-template-columns: 64px minmax(0, 1fr);
        gap: 14px;
        align-items: start;
    }

    .brand-mark{
        width: 64px;
        min-width: 64px;
        height: 64px;
    }

    .brand-copy .eyebrow{
        font-size: 0.78rem;
        line-height: 1.35;
        letter-spacing: 0.08em;
    }

    .brand-copy h1{
        font-size: clamp(1.75rem, 7vw, 2.4rem);
        line-height: 1.14;
        margin-bottom: 12px;
    }

    .brand-copy .subtitle{
        font-size: 0.98rem;
        line-height: 1.6;
        max-width: none;
    }

    .hero-badges{
        display: flex;
        flex-wrap: wrap;
        gap: 8px;
    }

    .hero-actions{
        display: grid;
        grid-template-columns: 1fr;
        gap: 10px;
        width: 100%;
    }

    .hero-actions .btn,
    .hero-actions a.btn,
    .hero-actions button{
        width: 100%;
        justify-content: center;
    }

    .overview-grid,
    .stats-grid,
    .year-meta,
    .group-cards,
    .search-row{
        display: grid;
        grid-template-columns: 1fr;
        gap: 12px;
    }

    .group-card{
        min-height: auto;
    }

    .stats-stack,
    .admin-stats-grid,
    .notice-grid,
    .form-grid,
    .metric-grid,
    .metric-grid.compact-grid{
        grid-template-columns: 1fr;
    }

    .field-span-2{grid-column:auto}

    .search-toolbar,
    .action-row,
    .topbar-actions{flex-direction:column}

    .search-toolbar > *,
    .action-row > *,
    .topbar-actions > *{width:100%}

    .topbar-actions .btn,
    .btn{width:100%}

    .site-header{padding:22px 0 24px}
    .hero-card,.content-card,.empty-state,.setup-card,.admin-header,.admin-tab{padding:18px}
    .admin-main{padding:18px}
    .panel-brand .brand-system-logo{min-width:0;width:100%;height:auto}
    .hero-system-logo{width:min(100%, 220px);min-width:0}
}


/* ===== UI refinement patch: full system display polish ===== */
html{scroll-behavior:smooth}
body{font-size:16px}
::selection{background:rgba(93,51,162,.16);color:var(--primary-dark)}

.site-header{padding:34px 0 32px}
.site-header .container{position:relative;z-index:1}
.brand-lockup{
    display:grid;
    grid-template-columns:auto minmax(0,1fr);
    align-items:start;
    gap:18px;
    width:100%;
    max-width:980px;
}
.brand-logo-group{align-self:start}
.brand-logo{
    width:88px;
    height:88px;
    padding:10px;
    border-radius:26px;
}
.brand-copy{min-width:0}
.brand-copy h1{font-weight:800;letter-spacing:-.02em;max-width:none}
.brand-copy .subtitle{max-width:920px;line-height:1.72}
.quick-badges{margin-top:4px}
.topbar-actions{justify-content:flex-end;align-items:flex-start}
.topbar-actions .btn{min-width:150px}

.main-layout{padding:26px 0 36px}
.hero-grid{align-items:stretch}
.hero-card,
.content-card,
.admin-header,
.admin-tab,
.setup-card,
.empty-state{
    border:1px solid rgba(255,255,255,.40);
    box-shadow:0 18px 44px rgba(48, 24, 96, .12);
}
.hero-card{padding:28px;min-height:100%}
.hero-card h2{font-size:clamp(1.6rem,2.2vw,2.3rem);line-height:1.24;max-width:none}
.hero-card p{max-width:920px}

.stats-stack,.admin-stats-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
.stat-card{min-height:134px;display:flex;flex-direction:column;justify-content:space-between}
.stat-value{line-height:1.05}

.search-toolbar{
    align-items:stretch;
    gap:12px;
}
.search-toolbar.search-toolbar-stacked{
    display:grid;
    grid-template-columns:repeat(4,minmax(0,1fr));
    gap:12px;
}
.search-toolbar.search-toolbar-stacked > *{
    min-width:0;
    width:100%;
}
.search-toolbar .btn{min-width:140px}
.search-toolbar input,
.search-toolbar select,
.field input,
.field select,
.field textarea{
    min-height:50px;
    border-radius:18px;
}
.field textarea{min-height:128px}
.field label{font-size:.95rem;color:#31425d}

.section-block{margin-bottom:20px}
.section-head{margin-bottom:14px}
.section-head h3{font-size:1.34rem}
.section-note{max-width:780px;line-height:1.65}
.notice-banner{
    padding:16px 18px;
    border-radius:22px;
    background:linear-gradient(135deg, rgba(255,255,255,.72), rgba(255,255,255,.54));
    border:1px solid rgba(255,255,255,.42);
}
.year-meta-grid{
    grid-template-columns:repeat(4,minmax(0,1fr));
    gap:14px;
}
.year-meta-item{
    min-height:112px;
    display:flex;
    flex-direction:column;
    justify-content:center;
}
.year-meta-item.wide{grid-column:span 1}
.year-meta-item:first-child{grid-column:span 2}
.year-meta-value{font-size:1.06rem;line-height:1.56}

.category-grid{
    grid-template-columns:repeat(auto-fit,minmax(235px,1fr));
    align-items:stretch;
}
.category-card{
    min-height:188px;
    display:flex;
    flex-direction:column;
    align-items:flex-start;
    text-align:left;
}
.category-card .metric-row{margin-top:auto;padding-top:12px;width:100%}
.category-card.active{
    background:linear-gradient(135deg, rgba(255,255,255,.84), rgba(245,255,250,.66));
}

.two-col-40{align-items:start}
.content-card{padding:24px}
.sticky-card{top:22px}
.items-meta{font-weight:600}

.table-wrap{border-radius:20px}
.data-table{min-width:680px}
.data-table thead th{white-space:nowrap}
.data-table tbody tr.active-row,
.data-table tbody tr.active-row:hover{
    background:linear-gradient(135deg, rgba(93,51,162,.12), rgba(29,138,104,.10));
}
.data-table tbody tr td:first-child{font-weight:700}

.detail-panel{
    gap:16px;
}
.detail-title{font-size:1.42rem;line-height:1.32}
.detail-description,.detail-details{font-size:1rem;line-height:1.76}
.detail-code{gap:8px}
.metric-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.metric-grid.compact-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
.metric-box{
    min-height:92px;
    display:flex;
    flex-direction:column;
    justify-content:space-between;
}
.metric-box span{color:var(--text-soft);font-size:.93rem;font-weight:600}
.metric-box strong{font-size:1.15rem;line-height:1.28;color:var(--primary-dark)}
.structured-public{
    padding:16px 18px;
    border:1px solid rgba(255,255,255,.38);
    border-radius:20px;
    background:rgba(255,255,255,.50);
}
.structured-public table{
    width:100%;
    border-collapse:collapse;
    margin-top:10px;
}
.structured-public th,
.structured-public td{
    border:1px solid rgba(108,88,154,.12);
    padding:10px 12px;
    text-align:left;
}
.structured-public th{background:rgba(93,51,162,.06)}
.attachment-list{gap:12px}
.attachment-item{
    align-items:flex-start;
}
.attachment-item .btn{min-width:120px}
.rating-box{
    padding:18px;
}
.rating-form .action-row{align-items:center}

.feature-list{gap:14px}
.feature-item{line-height:1.65}

.footer-inner{padding-top:18px}

.setup-wrap{padding:32px}
.setup-card{max-width:760px;padding:30px}
.setup-card h1{margin:0 0 8px;font-size:2rem}

.admin-shell{
    display:grid;
    grid-template-columns:320px minmax(0,1fr);
    min-height:100vh;
}
.admin-sidebar{
    position:sticky;
    top:0;
    height:100vh;
    padding:24px 18px;
    overflow:auto;
    gap:18px;
}
.sidebar-brand{padding-bottom:8px;border-bottom:1px solid rgba(255,255,255,.12)}
.sidebar-brand h2{font-size:1.3rem}
.sidebar-nav{gap:9px}
.nav-link{font-weight:700}
.nav-link.active,.nav-link:hover{transform:translateX(4px)}
.admin-main{padding:26px 24px 28px}
.admin-header{padding:24px 26px}
.admin-stats-grid{grid-template-columns:repeat(4,minmax(0,1fr));margin-bottom:18px}
.admin-tab{padding:22px}
.admin-items-layout{grid-template-columns:minmax(0,1.05fr) minmax(0,.95fr)}
.admin-table-wrap{max-height:620px}
.locked-form-shell{gap:18px}
.locked-form-mount{gap:18px}
.monthly-table-field .table-wrap{margin-top:8px}
.repeater-row,.checklist-item{gap:14px}
.inline-status{min-height:24px}

.list-stack{gap:12px}
.list-item-card,
.list-item,
.feedback-item,
.audit-item{
    align-items:flex-start;
}
.list-item-card.active-outline,
.category-card.active,
.attachment-item.button-like:hover,
.list-item-card.button-like:hover{
    border-color:rgba(93,51,162,.30);
    box-shadow:0 18px 34px rgba(45,25,94,.14);
}

.small-text,.list-meta,.file-meta,.mini-note,.section-note,.stat-sub{line-height:1.6}
.code-pill,.file-badge,.badge,.status-pill{line-height:1.2}

@media (min-width: 1440px){
    .container{width:min(95%, 1820px)}
    .site-header .container,
    main.container.main-layout{width:min(95%, 1820px);max-width:none}
    .hero-grid-wide{grid-template-columns:minmax(0,1.85fr) minmax(360px,.75fr)}
    .two-col-40{grid-template-columns:minmax(0,1.48fr) minmax(420px,.82fr)}
}

@media (min-width: 1024px){
    .topbar{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:start;gap:24px}
    .topbar-actions{display:grid;grid-auto-flow:row;gap:12px}
    .stats-stack{grid-template-columns:repeat(2,minmax(0,1fr))}
}

@media (max-width: 1279.98px){
    .search-toolbar.search-toolbar-stacked{grid-template-columns:repeat(2,minmax(0,1fr))}
    .year-meta-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
    .year-meta-item:first-child{grid-column:span 2}
    .admin-stats-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}

@media (max-width: 1180px){
    .admin-shell{grid-template-columns:1fr}
    .admin-sidebar{
        position:relative;
        top:auto;
        height:auto;
        border-radius:0 0 26px 26px;
    }
    .admin-items-layout,
    .two-col,
    .two-col-40,
    .hero-grid,
    .hero-grid-wide,
    .grid-2{grid-template-columns:1fr}
    .sticky-card{position:static}
    .sidebar-nav{display:flex;overflow:auto;padding-bottom:4px}
    .nav-link{white-space:nowrap;min-width:max-content}
}

@media (max-width: 1023.98px){
    .site-header{padding:26px 0 24px}
    .main-layout{padding:22px 0 30px}
    .brand-lockup{grid-template-columns:72px minmax(0,1fr);gap:14px}
    .brand-logo{width:72px;height:72px;border-radius:22px}
    .search-toolbar.search-toolbar-stacked{grid-template-columns:repeat(2,minmax(0,1fr))}
    .table-wrap{overflow:auto}
}

@media (max-width: 767.98px){
    .container{width:min(100% - 18px, 100% - 18px)}
    .site-header .container,
    main.container.main-layout{width:calc(100% - 18px);max-width:none}
    .brand-lockup{grid-template-columns:60px minmax(0,1fr);gap:12px}
    .brand-logo{width:60px;height:60px;border-radius:18px;padding:8px}
    .brand-copy h1{font-size:clamp(1.58rem, 6vw, 2.2rem);line-height:1.16}
    .brand-copy .subtitle{font-size:.98rem;line-height:1.62}
    .quick-badges{gap:8px}
    .quick-badge{font-size:.8rem;padding:6px 12px}
    .topbar-actions,
    .action-row,
    .search-toolbar{display:grid;grid-template-columns:1fr;gap:10px}
    .topbar-actions .btn,
    .action-row .btn,
    .search-toolbar .btn,
    .attachment-item .btn,
    .btn{width:100%;min-width:0}
    .hero-card,
    .content-card,
    .setup-card,
    .empty-state,
    .admin-header,
    .admin-tab{padding:18px}
    .search-toolbar.search-toolbar-stacked,
    .year-meta-grid,
    .stats-stack,
    .admin-stats-grid,
    .category-grid,
    .form-grid,
    .locked-grid,
    .metric-grid,
    .metric-grid.compact-grid,
    .notice-grid,
    .grid-2{grid-template-columns:1fr}
    .year-meta-item:first-child,
    .field-span-2{grid-column:auto}
    .data-table,
    .data-table thead,
    .data-table tbody,
    .data-table th,
    .data-table td,
    .data-table tr{display:block}
    .data-table{min-width:0}
    .data-table thead{display:none}
    .data-table tbody{display:grid;gap:12px;padding:12px}
    .data-table tbody tr{
        border:1px solid rgba(255,255,255,.38);
        border-radius:18px;
        background:linear-gradient(135deg, rgba(255,255,255,.72), rgba(255,255,255,.56));
        box-shadow:0 12px 24px rgba(45,25,94,.08);
        padding:10px 12px;
    }
    .data-table tbody td{
        display:grid;
        grid-template-columns:minmax(88px, 110px) minmax(0,1fr);
        gap:10px;
        padding:9px 0;
        border-bottom:1px dashed rgba(108,88,154,.10);
        align-items:start;
    }
    .data-table tbody td:last-child{border-bottom:0}
    .data-table tbody td::before{
        content:attr(data-label);
        font-weight:800;
        color:#4b3a73;
        font-size:.84rem;
        line-height:1.45;
    }
    .td-empty{padding:20px 10px}
    .attachment-item,
    .list-item-card,
    .list-item,
    .feedback-item,
    .audit-item{display:grid;gap:10px}
    .metric-box{min-height:0}
    .admin-main{padding:18px}
}
/* Year meta cleanup: remove the outer long background container behind the 4 summary boxes */
#yearMeta.notice-banner,
.notice-banner#yearMeta{
    padding:0;
    background:transparent;
    border:none;
    box-shadow:none;
    backdrop-filter:none;
    -webkit-backdrop-filter:none;
}

#yearMeta .year-meta-grid,
.notice-banner#yearMeta .year-meta-grid{
    grid-template-columns:minmax(420px, 2.4fr) repeat(3, minmax(180px, 1fr));
    gap:14px;
}

#yearMeta .year-meta-item,
.notice-banner#yearMeta .year-meta-item{
    min-height:110px;
}

#yearMeta .year-meta-item:first-child,
.notice-banner#yearMeta .year-meta-item:first-child{
    grid-column:auto;
}

#yearMeta .year-meta-value,
.notice-banner#yearMeta .year-meta-value{
    word-break:break-word;
}

@media (max-width: 1279.98px){
    #yearMeta .year-meta-grid,
    .notice-banner#yearMeta .year-meta-grid{
        grid-template-columns:repeat(2, minmax(0, 1fr));
    }

    #yearMeta .year-meta-item:first-child,
    .notice-banner#yearMeta .year-meta-item:first-child{
        grid-column:span 2;
    }
}

@media (max-width: 767.98px){
    #yearMeta .year-meta-grid,
    .notice-banner#yearMeta .year-meta-grid{
        grid-template-columns:1fr;
    }

    #yearMeta .year-meta-item:first-child,
    .notice-banner#yearMeta .year-meta-item:first-child{
        grid-column:auto;
    }
}
/* Auth / membership refinements */
.icon-btn{
    width:48px;
    min-width:48px;
    padding:0;
}
.icon-btn svg{
    width:22px;
    height:22px;
}
.member-chip{
    display:inline-flex;
    align-items:center;
    min-height:40px;
    padding:8px 14px;
    border-radius:999px;
    background:rgba(255,255,255,.12);
    color:#fff;
    border:1px solid rgba(255,255,255,.22);
    backdrop-filter:blur(12px) saturate(140%);
    -webkit-backdrop-filter:blur(12px) saturate(140%);
    font-weight:700;
}
.member-required-box h4{
    margin:0 0 8px;
}
.member-required-box p{
    margin:0;
    color:var(--text-soft);
}
.two-col-60-40{
    grid-template-columns:minmax(0,3fr) minmax(320px,2fr);
}
@media (max-width: 1199.98px){
    .two-col-60-40{
        grid-template-columns:1fr;
    }
}
.user-admin-grid{
    margin-top:10px;
}
.wrap-end{
    justify-content:flex-end;
}

/* Fix spacing between year meta boxes and indicator group cards */
#yearMeta,
.notice-banner#yearMeta {
    margin-bottom: 22px !important;
}

#groupCards,
.category-grid#groupCards {
    margin-top: 0 !important;
}

#yearMeta + #groupCards,
.notice-banner#yearMeta + #groupCards,
#yearMeta + .category-grid,
.notice-banner#yearMeta + .category-grid {
    margin-top: 22px !important;
}

/* Keep cards from visually sticking together */
#groupCards .category-card,
.category-grid#groupCards .category-card {
    margin-top: 0;
}

@media (min-width: 1200px) {
    #yearMeta,
    .notice-banner#yearMeta {
        margin-bottom: 24px !important;
    }

    #yearMeta + #groupCards,
    .notice-banner#yearMeta + #groupCards,
    #yearMeta + .category-grid,
    .notice-banner#yearMeta + .category-grid {
        margin-top: 24px !important;
    }
}

@media (max-width: 767.98px) {
    #yearMeta,
    .notice-banner#yearMeta {
        margin-bottom: 16px !important;
    }

    #yearMeta + #groupCards,
    .notice-banner#yearMeta + #groupCards,
    #yearMeta + .category-grid,
    .notice-banner#yearMeta + .category-grid {
        margin-top: 16px !important;
    }
}


/* ===== Compact public header / smaller export controls ===== */
.site-header{
    padding:18px 0 18px;
}

.topbar{
    align-items:flex-start;
    gap:18px;
}

.brand-lockup{
    max-width:1100px;
    gap:14px;
}

.brand-logo-group{
    gap:10px;
}

.brand-logo{
    width:68px;
    height:68px;
    padding:8px;
    border-radius:20px;
}

.brand-system-logo{
    height:68px;
    min-width:180px;
    padding:6px 10px;
    border-radius:20px;
}

.eyebrow{
    font-size:.72rem;
    letter-spacing:.14em;
}

.brand-copy h1,
.admin-header h1{
    margin:2px 0 4px;
    font-size:clamp(1.45rem,2.25vw,2.1rem);
    line-height:1.12;
}

.subtitle,
.brand-copy .subtitle{
    font-size:.94rem;
    line-height:1.5;
    max-width:900px;
}

.quick-badges{
    gap:8px;
    margin-top:8px;
}

.quick-badge{
    min-height:28px;
    padding:4px 12px;
    font-size:.8rem;
}

.topbar-actions{
    gap:10px;
}

.topbar-actions .btn,
.topbar-actions a.btn,
.topbar-actions button{
    min-width:118px;
    min-height:36px;
    padding:6px 12px;
    border-radius:14px;
    font-size:.92rem;
    line-height:1.1;
}

.topbar-actions .btn.icon-only,
.topbar-actions a.btn.icon-only,
.topbar-actions button.icon-only,
.topbar-actions .btn[aria-label="เข้าสู่ระบบ"],
.topbar-actions a.btn[aria-label="เข้าสู่ระบบ"],
.topbar-actions button[aria-label="เข้าสู่ระบบ"]{
    min-width:56px;
    width:56px;
    padding:6px;
}

@media (min-width: 1024px){
    .site-header{
        padding:16px 0 16px;
    }

    .topbar{
        grid-template-columns:minmax(0,1fr) auto;
        gap:18px;
        align-items:start;
    }

    .topbar-actions{
        display:grid;
        grid-auto-flow:row;
        gap:10px;
        align-content:start;
    }

    .topbar-actions .btn,
    .topbar-actions a.btn,
    .topbar-actions button{
        justify-self:end;
    }
}

@media (max-width: 1023.98px){
    .site-header{
        padding:16px 0 18px;
    }

    .brand-lockup{
        grid-template-columns:64px minmax(0,1fr);
        gap:12px;
    }

    .brand-logo{
        width:64px;
        height:64px;
        border-radius:18px;
    }

    .brand-copy h1,
    .admin-header h1{
        font-size:clamp(1.28rem,4.6vw,1.82rem);
    }
}

@media (max-width: 767.98px){
    .site-header{
        padding:14px 0 16px;
    }

    .brand-lockup{
        grid-template-columns:56px minmax(0,1fr);
        gap:10px;
    }

    .brand-logo{
        width:56px;
        height:56px;
        border-radius:16px;
        padding:7px;
    }

    .eyebrow{
        font-size:.68rem;
    }

    .brand-copy h1,
    .admin-header h1{
        margin:2px 0 4px;
        font-size:clamp(1.18rem,5.3vw,1.58rem);
        line-height:1.18;
    }

    .subtitle,
    .brand-copy .subtitle{
        font-size:.9rem;
        line-height:1.48;
    }

    .quick-badges{
        gap:6px;
        margin-top:6px;
    }

    .quick-badge{
        min-height:26px;
        padding:4px 10px;
        font-size:.76rem;
    }

    .topbar-actions,
    .action-row,
    .search-toolbar{
        gap:8px;
    }

    .topbar-actions .btn,
    .topbar-actions a.btn,
    .topbar-actions button{
        min-height:34px;
        padding:6px 10px;
        font-size:.88rem;
        border-radius:12px;
    }
}


/* ===== Public hero title/subtitle size refinement ===== */
.brand-copy h1{
    font-size:26px !important;
    line-height:1.2 !important;
}

.subtitle,
.brand-copy .subtitle{
    font-size:18px !important;
    line-height:1.45 !important;
}

@media (max-width: 767.98px){
    .brand-copy h1{
        font-size:26px !important;
        line-height:1.2 !important;
    }

    .subtitle,
    .brand-copy .subtitle{
        font-size:18px !important;
        line-height:1.45 !important;
    }
}

/* ===== Public header / hero typography refinement (latest) ===== */
.site-header .eyebrow{
    font-size:14px !important;
    line-height:1.35 !important;
    letter-spacing:.08em !important;
}

.brand-copy h1{
    font-size:26px !important;
    line-height:1.2 !important;
}

.site-header .subtitle,
.site-header .brand-copy .subtitle{
    font-size:20px !important;
    line-height:1.4 !important;
    max-width:980px;
}

.hero-card h2{
    font-size:20px !important;
    line-height:1.35 !important;
}

.hero-card > p,
.hero-card .detail-description,
.hero-card .detail-details{
    font-size:16px !important;
    line-height:1.6 !important;
}

@media (max-width: 767.98px){
    .site-header .eyebrow{
        font-size:14px !important;
        line-height:1.35 !important;
    }

    .brand-copy h1{
        font-size:26px !important;
        line-height:1.2 !important;
    }

    .site-header .subtitle,
    .site-header .brand-copy .subtitle{
        font-size:20px !important;
        line-height:1.4 !important;
    }

    .hero-card h2{
        font-size:20px !important;
        line-height:1.35 !important;
    }

    .hero-card > p,
    .hero-card .detail-description,
    .hero-card .detail-details{
        font-size:16px !important;
        line-height:1.6 !important;
    }
}

/* Topbar action layout refinement: user/admin controls on row 1, export controls on row 2 */
.topbar-user-name{
    white-space:nowrap;
}

@media (min-width: 1024px){
    .site-header .topbar-actions{
        display:grid;
        grid-template-columns:repeat(3, auto);
        justify-content:end;
        justify-items:end;
        align-items:center;
        column-gap:10px;
        row-gap:10px;
    }

    .site-header .topbar-user-name{
        grid-column:1;
        grid-row:1;
        align-self:center;
    }

    .site-header .topbar-admin-link,
    .site-header .topbar-login-link,
    .site-header .topbar-home-link{
        grid-column:2;
        grid-row:1;
        justify-self:end;
    }

    .site-header .topbar-logout-link{
        grid-column:3;
        grid-row:1;
        justify-self:end;
    }

    .site-header .topbar-export-link{
        grid-row:2;
        min-width:132px;
    }

    .site-header .export-json-link{
        grid-column:2;
    }

    .site-header .export-csv-link{
        grid-column:3;
    }

    .site-header .topbar-actions .btn,
    .site-header .topbar-actions a.btn,
    .site-header .topbar-actions button{
        margin:0;
    }
}

@media (max-width: 1023.98px){
    .site-header .topbar-actions{
        display:flex;
        flex-wrap:wrap;
        justify-content:flex-end;
        align-items:center;
        gap:10px;
    }

    .site-header .topbar-user-name{
        order:1;
    }

    .site-header .topbar-admin-link,
    .site-header .topbar-login-link,
    .site-header .topbar-home-link{
        order:2;
    }

    .site-header .topbar-logout-link{
        order:3;
    }

    .site-header .topbar-export-link{
        order:4;
    }
}
/* ===== Year meta info box compact height patch ===== */
#yearMeta .year-meta-item,
.notice-banner#yearMeta .year-meta-item{
    min-height:auto !important;
    height:auto !important;
    padding:16px 18px !important;
    display:flex;
    flex-direction:column;
    justify-content:center;
}

#yearMeta .year-meta-label,
.notice-banner#yearMeta .year-meta-label{
    margin-bottom:6px !important;
    line-height:1.2 !important;
}

#yearMeta .year-meta-value,
.notice-banner#yearMeta .year-meta-value{
    margin:0 !important;
    line-height:1.3 !important;
}

@media (min-width: 1200px){
    #yearMeta .year-meta-item,
    .notice-banner#yearMeta .year-meta-item{
        min-height:auto !important;
        height:auto !important;
        padding:14px 18px !important;
    }
}

@media (max-width: 767.98px){
    #yearMeta .year-meta-item,
    .notice-banner#yearMeta .year-meta-item{
        min-height:auto !important;
        height:auto !important;
        padding:14px 16px !important;
    }
}