body{font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;margin:0;background:var(--bg);color:var(--text)}a{color:inherit;text-decoration:none}

:root{--brand:#F2B90C;--brand2:#F2D22E;--accent:#F27405;--ink:#401005;--text:#401005;--bg:#F2F2F2;--card:#fff;--border:#e6e8f1;--radius:16px;--radius-sm:12px;--shadow:0 10px 26px rgba(64,16,5,.08)}

.app-shell{min-height:100vh}
.topbar{display:flex;justify-content:space-between;align-items:center;padding:12px 14px;background:linear-gradient(90deg,var(--brand) 0%,var(--brand2) 65%,#fff 140%);color:var(--ink);position:sticky;top:0;z-index:5;box-shadow:var(--shadow)}
.topbar .brand a{font-weight:800;letter-spacing:-.3px}
.topbar .right a{color:var(--ink)!important}
.topbar .right .muted{color:rgba(64,16,5,.75)}
.brand-lockup{display:flex;align-items:center;gap:10px}
.brand-lockup .brand-icon{width:34px;height:34px;object-fit:contain;border-radius:12px;background:rgba(255,255,255,.65);border:1px solid rgba(64,16,5,.12)}
.brand-text-logo{height:28px;width:auto;max-width:min(240px,52vw);object-fit:contain;background:transparent!important;border:0!important;border-radius:0!important}
.container{max-width:980px;margin:16px auto;padding:0 14px}
.admin-container{max-width:1400px}
.app-container{padding-bottom:78px}
.narrow{max-width:420px}

.field{margin:12px 0}
.field label{display:block;margin-bottom:6px;color:#333;font-size:13px}
input{width:100%;padding:10px 12px;border:1px solid #d5d7e2;border-radius:14px;background:#fff;box-sizing:border-box}
select{width:100%;padding:10px 12px;border:1px solid #d5d7e2;border-radius:14px;background:#fff;box-sizing:border-box}
button{padding:10px 14px;border:0;border-radius:14px;background:var(--brand);color:var(--ink);font-weight:900;cursor:pointer;box-shadow:0 10px 22px rgba(242,185,12,.25)}
button:hover{opacity:.95}
button:focus-visible{outline:3px solid rgba(242,116,5,.35);outline-offset:2px}
input:focus,select:focus{outline:0;border-color:rgba(242,116,5,.65);box-shadow:0 0 0 4px rgba(242,116,5,.16)}
.alert{padding:10px 12px;background:#ffe9e9;border:1px solid #ffbcbc;border-radius:12px;margin:10px 0}
.muted{color:#666;font-size:13px}

.cards{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:14px;box-shadow:0 8px 18px rgba(64,16,5,.05)}
.card .label{font-size:13px;color:#666;margin-bottom:10px}
.card .big{font-size:26px;font-weight:900}

.card.soft{background:linear-gradient(180deg,#fff 0%,rgba(242,242,242,.85) 100%)}
.card.sun{background:linear-gradient(180deg,rgba(242,210,46,.22) 0%,rgba(255,255,255,.96) 60%);border-color:rgba(242,185,12,.35)}

.subnav{display:flex;gap:10px;margin:10px 0 16px;flex-wrap:wrap}
.subnav a{padding:8px 10px;background:var(--card);border:1px solid var(--border);border-radius:14px}
.subnav a .icon{width:16px;height:16px;vertical-align:-3px}

.table{width:100%;border-collapse:collapse;background:var(--card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;box-shadow:0 8px 18px rgba(64,16,5,.05)}
.table th,.table td{padding:10px;border-bottom:1px solid #eef0f7;text-align:left;font-size:14px;vertical-align:top}
.table th{background:#fff8db;color:var(--ink)}

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

.tabbar{position:fixed;left:0;right:0;bottom:0;background:rgba(255,255,255,.92);backdrop-filter:saturate(180%) blur(10px);border-top:1px solid var(--border);display:flex;justify-content:space-around;gap:4px;padding:10px 8px;z-index:10}
.tabbar .tab{flex:1;text-align:center;padding:10px 0;border-radius:12px;font-weight:800;color:#333}
.tabbar .tab:active{background:#fff0b8}

.list{display:flex;flex-direction:column;gap:10px}
.list-item{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:12px 14px;box-shadow:0 8px 18px rgba(64,16,5,.05)}
.list-item .title{font-weight:900}
.list-item .meta{margin-top:6px;color:#666;font-size:13px}

.row{display:flex;align-items:center;gap:10px}
.icon{width:20px;height:20px;flex:0 0 auto}
.section{margin-top:12px}
.section h2{margin:14px 0 8px;font-size:16px}
.pill{display:inline-block;padding:4px 10px;border-radius:999px;background:#fff0b8;border:1px solid rgba(242,185,12,.55);font-weight:900;font-size:12px;color:var(--ink);vertical-align:middle}

.btnLike{background:var(--brand2);color:var(--ink);box-shadow:0 10px 22px rgba(242,210,46,.24)}
.btnLike:hover{opacity:.96}
.btnLike.is-liked{background:var(--brand);box-shadow:0 10px 22px rgba(242,185,12,.30)}

.btnComment{background:var(--accent);color:#fff;box-shadow:0 10px 22px rgba(242,116,5,.24)}
.btnComment:hover{opacity:.96}

.podium{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin-top:12px}
.podium .slot{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:12px;text-align:center;box-shadow:0 8px 18px rgba(64,16,5,.05)}
.podium .rank{font-weight:900;font-size:16px}
.podium .name{font-weight:900;margin-top:8px}
.podium .pts{margin-top:6px;color:var(--accent);font-weight:900}
.medal1{border-color:#f2d36b;background:#fffaf0}
.medal2{border-color:#cfd7e6;background:#f9fbff}
.medal3{border-color:#e6c4a5;background:#fff7f1}

.hero{position:relative;overflow:hidden;background:linear-gradient(135deg,#fff2b8 0%,#fff7db 45%,#ffffff 100%);border:1px solid rgba(242,185,12,.45);border-radius:22px;padding:14px;box-shadow:0 12px 28px rgba(64,16,5,.10)}
.hero .hero-title{font-weight:900;font-size:18px;color:var(--ink)}
.hero .hero-sub{margin-top:6px;color:rgba(64,16,5,.75);font-size:13px;font-weight:700}
.hero .hero-img{position:absolute;right:8px;bottom:0;width:118px;max-height:120px;height:auto;object-fit:contain;filter:drop-shadow(0 18px 24px rgba(64,16,5,.18));pointer-events:none}
.hero .hero-logo{width:44px;height:44px;object-fit:contain;border-radius:14px;background:rgba(255,255,255,.75);border:1px solid rgba(64,16,5,.12)}

.hero-link{display:block;color:inherit;text-decoration:none}
.hero-link:active{transform:translateY(1px)}

.login-page{min-height:100vh;display:flex;align-items:center;background:
  radial-gradient(900px 360px at 20% 0%, rgba(242,185,12,.35) 0%, rgba(242,210,46,.18) 35%, rgba(255,255,255,0) 70%),
  radial-gradient(800px 340px at 90% 20%, rgba(242,116,5,.22) 0%, rgba(255,255,255,0) 60%),
  linear-gradient(180deg,#fff9e8 0%, var(--bg) 48%, #ffffff 110%);
}
.login-wrap{display:flex;flex-direction:column;gap:14px;margin:14px 0}
.login-hero{position:relative;overflow:hidden;background:linear-gradient(135deg,rgba(242,185,12,.22) 0%, rgba(242,210,46,.18) 40%, rgba(255,255,255,.96) 100%);border:1px solid rgba(242,185,12,.45);border-radius:22px;padding:16px 16px 14px;box-shadow:0 16px 34px rgba(64,16,5,.10)}
.login-hero-top{display:flex;align-items:center;gap:10px;min-height:44px}
.login-hero-logo{width:44px;height:44px;object-fit:contain;border-radius:14px;background:rgba(255,255,255,.78);border:1px solid rgba(64,16,5,.12)}
.login-hero-text{height:30px;width:auto;max-width:min(260px,62vw);object-fit:contain}
.login-hero-sub{margin-top:8px;color:rgba(64,16,5,.78);font-size:13px;font-weight:800;letter-spacing:-.2px}
.login-hero-char{position:absolute;right:10px;bottom:-6px;width:128px;max-height:140px;height:auto;object-fit:contain;filter:drop-shadow(0 18px 24px rgba(64,16,5,.18));pointer-events:none;user-select:none}

.login-card{border-radius:22px;padding:16px}
.login-title{font-weight:950;letter-spacing:-.4px;font-size:18px;color:var(--ink)}
.login-desc{margin-top:6px}
.login-btn{width:100%;margin-top:8px}
.login-help{margin-top:12px}

@media (max-width: 560px){
  .container{margin:12px auto}
  .cards{grid-template-columns:1fr}
  .table{display:block;overflow:auto}
  .podium{grid-template-columns:1fr}
  .login-page{align-items:stretch}
  .login-hero-char{width:116px;right:8px}
}


