:root{
    --bg:#0a0a0a;
    --fg:#f8f4e3;
    --accent:#d0a84b;
    --border:#333;
    --hl:#1c1c1c;
    --red:#b33;
    --green:#63b36d;
    --warn:#d6a23a;
    --soft:#151515;
    --soft2:#181818;
    --dimPriority:#221c10;
    --sumCol:#1f1b12;
    --purple:#a66bff;
}

*{box-sizing:border-box}

html, body{
    width:100%;
    min-height:100%;
}

body{
    background:var(--bg);
    color:var(--fg);
    font-family:Segoe UI,Arial,sans-serif;
    margin:0;
}

/* =========================
   LOGIN SCREEN WITH ART
   ========================= */
/* =========================
   LOGIN SCREEN WITH ART
   ========================= */

:root{
    --login-box-x: 50%;
    --login-box-y: 47%;
    --login-box-w: 320px;
}

#loginOverlay{
    position: fixed;
    inset: 0;
    z-index: 999;
    overflow: hidden;
    background: #000;
}

/* art scene */
#loginArtWrap{
    position: absolute;
    inset: 0;
    overflow: hidden;
}

/* actual image */
#loginArt{
    position: absolute;
    left: 50%;
    top: 50%;
    width: auto;
    height: auto;
    max-width: min(96vw, 1500px);
    max-height: 94vh;
    transform: translate(-50%, -50%);
    display: block;
    filter: brightness(0.92) saturate(1.02);
    animation: loginArtFloat 14s ease-in-out infinite;
}

/* dark blending */
#loginShade{
    position: absolute;
    inset: 0;
    pointer-events: none;
    background:
        radial-gradient(
            ellipse at center,
            rgba(0,0,0,0.02) 0%,
            rgba(0,0,0,0.06) 18%,
            rgba(0,0,0,0.14) 36%,
            rgba(0,0,0,0.30) 55%,
            rgba(0,0,0,0.56) 74%,
            rgba(0,0,0,0.82) 90%,
            #000 100%
        ),
        linear-gradient(
            to bottom,
            rgba(0,0,0,0.30) 0%,
            rgba(0,0,0,0.08) 22%,
            rgba(0,0,0,0.08) 78%,
            rgba(0,0,0,0.34) 100%
        );
}

#loginShade::after{
    content:"";
    position:absolute;
    inset:0;
    pointer-events:none;

    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);

    mask-image: radial-gradient(
        ellipse at center,
        transparent 55%,
        black 85%
    );

    -webkit-mask-image: radial-gradient(
        ellipse at center,
        transparent 55%,
        black 85%
    );
}

/* subtle life */
#loginSparkles{
    position: absolute;
    inset: 0;
    pointer-events: none;
    opacity: 0.35;
    background-image:
        radial-gradient(circle at 20% 30%, rgba(255,220,120,0.9) 0 1px, transparent 2px),
        radial-gradient(circle at 72% 22%, rgba(255,210,120,0.8) 0 1px, transparent 2px),
        radial-gradient(circle at 60% 72%, rgba(255,230,160,0.7) 0 1px, transparent 2px),
        radial-gradient(circle at 38% 66%, rgba(255,210,120,0.8) 0 1px, transparent 2px),
        radial-gradient(circle at 82% 58%, rgba(255,220,120,0.7) 0 1px, transparent 2px);
    animation: loginSparklesPulse 6s ease-in-out infinite;
}

/* box is positioned directly, not flex-centered */
#loginBox{
    position:absolute;
    left:var(--login-box-x);
    top:var(--login-box-y);
    transform:translate(-50%, -50%);
    z-index:2;

    width:min(88vw, 300px);
    padding:12px 14px;

    /* REMOVE the box */
    background:transparent;
    border:none;
    box-shadow:none;
    backdrop-filter:none;
    -webkit-backdrop-filter:none;

    text-align:center;
    color:var(--fg);
}

#loginBox h2{
    margin:0 0 10px;
    font-size:22px;

    color:rgba(248,244,227,0.92);

    text-shadow:
        0 0 12px rgba(255,220,120,0.18),
        0 2px 8px rgba(0,0,0,0.5);
}

#loginBox input{
    width:100%;
    margin:8px 0;
    padding:11px 13px;

    background:rgba(0,0,0,0.35);
    color:var(--fg);

    border:1px solid rgba(255,255,255,0.12);
    border-radius:10px;

    outline:none;
    font-size:14px;

    backdrop-filter:blur(4px);
}

#loginBox input::placeholder{
    color:rgba(248,244,227,0.45);
}

#loginBox input:focus{
    border-color:rgba(208,168,75,0.6);
    box-shadow:0 0 12px rgba(208,168,75,0.2);
}

#loginBox::after{
    content:"";
    position:absolute;
    inset:-60px;
    z-index:-2;

    background:
        radial-gradient(
            ellipse at center,
            rgba(255,200,120,0.08),
            transparent 60%
        );

    animation: voidPulse 6s ease-in-out infinite;
}

@keyframes voidPulse{
    0%{opacity:0.2}
    50%{opacity:0.45}
    100%{opacity:0.2}
}

#loginBox::before{
    content:"";
    position:absolute;
    inset:-30px -40px;
    z-index:-1;

    background:
        radial-gradient(
            ellipse at center,
            rgba(0,0,0,0.55) 0%,
            rgba(0,0,0,0.35) 40%,
            rgba(0,0,0,0.15) 65%,
            transparent 85%
        );

    filter:blur(18px);
}


#loginBox button{
    width:100%;
    margin-top:6px;
    padding:10px 14px;

    background:rgba(208,168,75,0.85);
    color:#111;

    border:none;
    border-radius:10px;

    font-weight:700;
    font-size:14px;

    box-shadow:
        0 4px 18px rgba(208,168,75,0.25);

    transition:0.2s ease;
}

#loginBox button:hover{
    transform:translateY(-1px);
    filter:brightness(1.05);
}

#loginStatus{
    min-height: 18px;
    margin-top: 10px;
    font-size: 12px;
    color: rgba(216,200,155,0.90);
}

@keyframes loginArtFloat{
    0%   { transform: translate(-50%, -50%) scale(1); }
    50%  { transform: translate(-50%, calc(-50% - 6px)) scale(1.012); }
    100% { transform: translate(-50%, -50%) scale(1); }
}

@keyframes loginSparklesPulse{
    0%   { opacity: 0.20; }
    50%  { opacity: 0.36; }
    100% { opacity: 0.20; }
}

/* wider monitors */
@media (min-width: 1400px){
    :root{
        --login-box-y: 40%;
        --login-box-w: 330px;
    }

    #loginArt{
        max-width: min(94vw, 1650px);
        max-height: 95vh;
    }
}

/* normal laptop */
@media (max-width: 1200px){
    :root{
        --login-box-y: 41%;
        --login-box-w: 315px;
    }

    #loginArt{
        max-width: 98vw;
        max-height: 92vh;
    }
}

/* tablet-ish */
@media (max-width: 900px){
    :root{
        --login-box-y: 48%;
        --login-box-w: 300px;
    }

    #loginArt{
        max-width: 100vw;
        max-height: 88vh;
    }
}

@media (max-width: 600px){
    :root{
        --login-box-y: 49%;
        --login-box-w: 290px;
    }

    #loginArt{
        max-width: 104vw;
        max-height: 84vh;
    }

    #loginBox{
        padding: 16px 16px 14px;
        border-radius: 18px;
    }

    #loginBox h2{
        font-size: 21px;
    }

    #loginBox input,
    #loginBox button{
        font-size: 14px;
    }
}
/* =========================
   APP
   ========================= */

#app{
    display:none;
    padding:20px;
}

#pantryFloatBtns{
    position:fixed;
    right:20px;
    bottom:20px;
    display:flex;
    flex-direction:column;
    gap:10px;
    z-index:1001;
}

#pantryFloatBtns button{
    width:42px;
    height:42px;
    border:none;
    border-radius:999px;
    background:#1a1a1a;
    color:var(--fg);
    border:1px solid var(--accent);
    cursor:pointer;
    font-size:18px;
    box-shadow:0 4px 12px rgba(0,0,0,0.35);
}

.topbar{
    display:flex;
    gap:16px;
    align-items:end;
    flex-wrap:wrap;
    margin-bottom:16px;
}

.lastUpdateStamp{
    text-align:right;
    color:#8a8a8a;
    font-size:12px;
    margin-bottom:10px;
}

.field{
    display:flex;
    flex-direction:column;
    gap:6px;
}

label{
    font-size:13px;
    color:var(--accent);
}

select,input{
    background:#111;
    color:var(--fg);
    border:1px solid #444;
    border-radius:6px;
    padding:9px 10px;
}

.meta{
    margin:8px 0 18px;
    padding:12px 14px;
    background:#111;
    border:1px solid var(--border);
    border-radius:8px;
    display:flex;
    gap:18px;
    flex-wrap:wrap;
}

.tabs{
    display:flex;
    gap:10px;
    margin-bottom:15px;
    flex-wrap:wrap;
}

.tab{
    padding:8px 14px;
    background:var(--hl);
    border:1px solid var(--border);
    border-radius:4px;
    cursor:pointer;
}

.tab.active{
    background:var(--accent);
    color:#000;
}

.tabContent{
    display:none;
}

.panel{
    background:#111;
    padding:12px;
    border:1px solid var(--border);
    border-radius:10px;
}

.tableEmbed{
    overflow-x:auto;
    border:1px solid var(--border);
    border-radius:10px;
    background:#0d0d0d;
}

.tableEmbed::-webkit-scrollbar{
    height:12px;
}
.tableEmbed::-webkit-scrollbar-track{
    background:#111;
}
.tableEmbed::-webkit-scrollbar-thumb{
    background:#444;
    border-radius:999px;
}

table{
    width:100%;
    border-collapse:collapse;
    min-width:1200px;
}

th,td{
    padding:7px 10px;
    border-bottom:1px solid #333;
    white-space:nowrap;
    text-align:right;
}

th{
    background:#1a1a1a;
    color:var(--accent);
    cursor:pointer;
    position:sticky;
    top:0;
    z-index:1;
}

th.col-static{
    cursor:default;
}

th.left, td.left{
    text-align:left;
}

tr:nth-child(even){
    background:rgba(255,255,255,0.03);
}

tbody tr:hover td{
    background:rgba(208,168,75,0.12);
}

.zero-red{
    color:var(--red);
    font-weight:bold;
}

.status-green{
    color:var(--green);
    font-weight:bold;
}

.status-warn{
    color:var(--warn);
    font-weight:bold;
}

.status-red{
    color:var(--red);
    font-weight:bold;
}

.status-purple{
    color:var(--purple);
    font-weight:bold;
}

.status-neutral{
    color:#9a9a9a;
    font-weight:600;
}

.target-col{
    color:#e7d8a4;
    font-weight:600;
}

.smallNote{
    font-size:12px;
    opacity:0.8;
    margin-top:8px;
}

.checkboxRead{
    font-size:18px;
    line-height:1;
}

.pantryEntry{
    position:fixed;
    right:14px;
    bottom:10px;
    font-size:12px;
    color:#7e7e7e;
    background:#111;
    border:1px solid #2d2d2d;
    border-radius:999px;
    padding:6px 10px;
    cursor:pointer;
    z-index:50;
    opacity:0.8;
}

.pantryEntry:hover{
    opacity:1;
    color:#b8b8b8;
    border-color:#555;
}

.pantryOverlay{
    position:fixed;
    inset:0;
    background:#000b;
    display:none;
    align-items:center;
    justify-content:center;
    z-index:1000;
    padding:20px;
}

.pantryBox{
    width:min(1400px, 92vw);
    max-height:90vh;
    overflow:auto;
    background:#111;
    border:1px solid var(--accent);
    border-radius:12px;
    padding:18px;
}

.pantryHeader{
    display:flex;
    justify-content:space-between;
    align-items:center;
    gap:12px;
    margin-bottom:14px;
}

.pantrySections{
    display:grid;
    gap:18px;
}

.pantrySection{
    border:1px solid var(--border);
    border-radius:10px;
    padding:14px;
    background:#0d0d0d;
}

.pantrySection h3{
    margin:0 0 12px;
    color:var(--accent);
}

.pantryGrid{
    display:grid;
    grid-template-columns:repeat(3, minmax(140px, 220px));
    gap:10px;
    align-items:end;
}

.pantryActions{
    display:flex;
    gap:10px;
    flex-wrap:wrap;
    margin-top:12px;
}

.pantryBtn{
    padding:8px 14px;
    background:var(--accent);
    border:none;
    border-radius:6px;
    cursor:pointer;
    font-weight:bold;
}

.pantryBtn.secondary{
    background:#262626;
    color:var(--fg);
    border:1px solid #444;
}

.pantryStatus{
    margin-top:10px;
    font-size:13px;
    color:#9a9a9a;
}

.pantryTable{
    width:100%;
    border-collapse:collapse;
}

.pantryTable th,
.pantryTable td{
    padding:8px 10px;
    border-bottom:1px solid #2d2d2d;
    text-align:left;
    white-space:nowrap;
}

.pantryTable input,
.pantryTable select{
    width:100%;
}

.pantryMini{
    width:auto !important;
}

.pantryLockedBox{
    max-width:360px;
    margin:20px auto 0;
}

.pantryLockedTitle{
    margin:0 0 14px;
    color:var(--fg);
    font-size:20px;
    font-weight:700;
}

.pantryLockedBox .field{
    display:flex;
    flex-direction:column;
    gap:6px;
}

.pantryLockedBox .pantryActions{
    justify-content:flex-start;
}

.pantrySectionHeader{
    display:flex;
    justify-content:space-between;
    align-items:center;
    gap:12px;
    cursor:pointer;
    margin:0;
    color:var(--accent);
}

.pantrySectionHeader h3{
    margin:0;
    color:inherit;
}

.pantrySectionBody{
    margin-top:12px;
}

.pantrySection.collapsed .pantrySectionBody{
    display:none;
}

.pantryChevron{
    color:#9a9a9a;
    font-size:12px;
}

.pantrySearchWrap{
    margin-bottom:12px;
    max-width:320px;
}

.pantrySection.collapsed .pantrySectionBody{
    display:none;
}

.pantryGrid2{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
    gap:12px;
}

#pantryOmensBulk{
    background:#111;
    color:var(--fg);
    border:1px solid #444;
    border-radius:6px;
    padding:10px;
    font-family:Consolas, monospace;
}

.omen-flag{
    font-size:12px;
    padding:2px 6px;
    border-radius:999px;
    border:1px solid #555;
    display:inline-block;
}

.omen-flag.warn{
    color:var(--warn);
    border-color:var(--warn);
}

.omen-flag.red{
    color:var(--red);
    border-color:var(--red);
}

.status-rainbow{
    display:inline-block;
    background-image:linear-gradient(90deg,#ff4d4d,#ffb84d,#ffe84d,#66ff99,#66ccff,#9d66ff,#ff66cc);
    -webkit-background-clip:text;
    background-clip:text;
    -webkit-text-fill-color:transparent;
    color:transparent;
    font-weight:bold;
}

.fade-cell{
    background-color: rgba(208,168,75,var(--gold-fade, 0));
    transition: background-color 0.15s ease;
}

tbody tr:hover td.fade-cell{
    background-color: rgba(208,168,75,calc(var(--gold-fade, 0) + 0.06));
}

.stackingTopbar{
    display:flex;
    gap:16px;
    align-items:end;
    flex-wrap:wrap;
}

.stackingGridWrap{
    display:grid;
    grid-template-columns: minmax(700px, 1fr);
    gap:16px;
    margin-top:16px;
}

.stackingBlock{
    background:#0d0d0d;
    border:1px solid var(--border);
    border-radius:10px;
    padding:14px;
}

.stackingBlockTitle{
    color:var(--accent);
    font-weight:700;
    margin-bottom:12px;
}

.stackingInlineCheck{
    display:flex;
    align-items:center;
    gap:8px;
    color:var(--fg);
    margin-bottom:8px;
}

.stackingInlineCheck input{
    width:auto;
}

.stackingActions{
    display:flex;
    gap:10px;
    flex-wrap:wrap;
}

.stackingCaptainRow{
    display:grid;
    grid-template-columns: minmax(180px, 220px) 110px 170px 130px 170px;
    gap:10px;
    align-items:end;
    margin-bottom:10px;
}

.stackingHeroRow{
    display:flex;
    gap:16px;
    align-items:end;
    flex-wrap:wrap;
    margin-top:12px;
}

#stackingTroopGrid{
    display:grid;
    grid-template-columns: repeat(3, minmax(220px, 1fr));
    gap:14px;
}

#stackingMercGrid{
    display:grid;
    grid-template-columns: repeat(2, minmax(260px, 1fr));
    gap:10px;
}

.stackingTierCard{
    border:1px solid #2f2f2f;
    border-radius:10px;
    padding:10px;
    background:#111;
}

.stackingTierTitle{
    color:var(--accent);
    font-weight:700;
    margin-bottom:8px;
}

.stackingMainPick{
    margin-bottom:8px;
}

.stackingSubgrid{
    display:grid;
    grid-template-columns: repeat(2, minmax(90px, 1fr));
    gap:6px 12px;
}

.stackingSubgrid label,
.stackingMercItem label{
    display:flex;
    align-items:center;
    gap:8px;
    color:var(--fg);
    font-size:13px;
}

.stackingSubgrid input,
.stackingMercItem input,
.stackingMainPick input{
    width:auto;
}

.stackingMercItem{
    border:1px solid #2f2f2f;
    border-radius:10px;
    padding:10px;
    background:#111;
}

.stackingHint{
    color:#9a9a9a;
    font-size:12px;
}

@media (max-width: 1200px){
    .stackingCaptainRow{
        grid-template-columns: 1fr 100px 1fr 120px 1fr;
    }

    #stackingTroopGrid{
        grid-template-columns: repeat(2, minmax(220px, 1fr));
    }

    #stackingMercGrid{
        grid-template-columns: 1fr;
    }
}

@media (max-width: 800px){
    .stackingCaptainRow{
        grid-template-columns: 1fr;
    }

    #stackingTroopGrid{
        grid-template-columns: 1fr;
    }
}

.stackingSelectorArea{
    display:grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    gap:16px;
    margin-top:16px;
}

.stackingSelectorBlock{
    background:#0d0d0d;
    border:1px solid var(--border);
    border-radius:10px;
    padding:12px;
}

.stackingTierGrid{
    display:grid;
    grid-template-columns:repeat(auto-fit, minmax(88px, 1fr));
    gap:10px;
    align-items:start;
}

.stackingTierCol{
    background:#111;
    border:1px solid #2a2a2a;
    border-radius:8px;
    padding:8px;
    min-height:150px;
}

.stackingTierHead{
    display:flex;
    align-items:center;
    gap:6px;
    margin-bottom:8px;
    color:var(--accent);
    font-weight:700;
}

.stackingTierItems{
    display:grid;
    gap:6px;
}

.stackingMiniCheck{
    display:flex;
    align-items:center;
    gap:6px;
    font-size:12px;
    color:var(--fg);
}

.stackingMiniCheck input{
    width:auto;
    margin:0;
}

.stackingMercGroup{
    border:1px solid #2a2a2a;
    border-radius:8px;
    background:#111;
    margin-bottom:10px;
    overflow:hidden;
}

.stackingMercGroupHead{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:10px;
    padding:10px 12px;
    cursor:pointer;
    color:var(--accent);
    font-weight:700;
    background:#141414;
}

.stackingMercGroupBody{
    display:none;
    padding:10px 12px;
    border-top:1px solid #222;
}

.stackingMercGroup.open .stackingMercGroupBody{
    display:block;
}

.stackingMercList{
    display:grid;
    gap:6px;
}

.stackingMercChevron{
    color:#9a9a9a;
    font-size:12px;
}

.stackingMercGroupTitle{
    color:var(--accent);
    font-size:13px;
    font-weight:700;
    margin-bottom:8px;
}

.stackingMercList{
    display:grid;
    gap:6px;
}

@media (max-width: 1100px){
    .stackingSelectorArea{
        grid-template-columns:1fr;
    }
}