:root{--font-display: "Inter", "Noto Sans JP", system-ui, sans-serif;--font-digit: "Inter", "Noto Sans JP", system-ui, sans-serif;--font-body: "Noto Sans JP", "Inter", system-ui, sans-serif;--color-bg: #f5f7fb;--color-bg-soft: #eef2f8;--color-surface: #ffffff;--color-surface-elevated: #fbfcfe;--color-border: #e3e8f2;--color-border-strong: #cbd5e6;--color-text: #1d2433;--color-text-muted: #5b6575;--color-text-subtle: #94a3b8;--color-primary: #2563eb;--color-primary-dark: #1d4ed8;--color-primary-soft: #eff4ff;--color-gold: #b45309;--color-gold-light: #fef3e2;--color-gold-muted: #e8c889;--color-success: #15803d;--color-success-bg: #effaf2;--color-warning: #b45309;--color-warning-bg: #fdf6e9;--color-danger: #dc2626;--color-danger-bg: #fdf1f1;--shadow-sm: 0 1px 2px rgb(29 36 51 / 5%);--shadow-md: 0 8px 24px rgb(29 36 51 / 8%);--shadow-lg: 0 16px 48px rgb(29 36 51 / 12%);--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-full: 999px;--header-h: 4.5rem;--mobile-nav-h: 4.25rem}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;font-family:var(--font-body);font-size:.9375rem;line-height:1.65;color:var(--color-text);background:var(--color-bg);background-image:radial-gradient(ellipse 70% 45% at 50% -5%,rgb(37 99 235 / 7%),transparent),linear-gradient(180deg,#fafbfe 0%,var(--color-bg) 50%);min-height:100dvh}a{color:var(--color-primary);text-decoration:none;transition:color .15s ease}a:hover{color:var(--color-primary-dark)}.app-shell{min-height:100dvh;display:flex;flex-direction:column}.site-header{position:sticky;top:0;z-index:50;display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.85rem 1.25rem;background:#ffffffdb;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--color-border)}.site-header__brand{min-width:0}.site-header__eyebrow{margin:0;font-family:var(--font-display);font-size:.625rem;letter-spacing:.16em;text-transform:uppercase;color:var(--color-primary);font-weight:700}.site-header__title{margin:.1rem 0 0;font-family:var(--font-display);font-size:clamp(.95rem,2.5vw,1.15rem);font-weight:800;line-height:1.25;color:var(--color-text)}.site-header__title-short{display:none}@media(max-width:899px){.site-header{padding:.65rem 1rem}.site-header__title-full{display:none}.site-header__title-short{display:inline;font-size:1.05rem}}.site-header__user{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.site-header__name{font-size:.8125rem;color:var(--color-text-muted);display:none}@media(min-width:640px){.site-header__name{display:block}}.mobile-sub-nav{display:flex;align-items:center;gap:.4rem;overflow-x:auto;padding:.5rem 1rem;border-bottom:1px solid var(--color-border);background:var(--color-surface);-webkit-overflow-scrolling:touch;scrollbar-width:none}.mobile-sub-nav::-webkit-scrollbar{display:none}.mobile-sub-nav a,.mobile-sub-nav__logout{flex-shrink:0;display:inline-flex;align-items:center;padding:.4rem .85rem;border-radius:var(--radius-full);font-size:.75rem;font-weight:600;color:var(--color-primary);text-decoration:none;background:var(--color-primary-soft);border:1px solid rgb(37 99 235 / 14%);white-space:nowrap}.mobile-sub-nav a.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.mobile-sub-nav__logout{font-family:var(--font-body);cursor:pointer;background:var(--color-bg-soft);color:var(--color-text-muted);border-color:var(--color-border)}@media(min-width:900px){.mobile-sub-nav{display:none}}.site-nav{display:none;flex-wrap:wrap;gap:.35rem;padding:.65rem 1.25rem;border-bottom:1px solid var(--color-border);background:var(--color-surface)}@media(min-width:900px){.site-nav{display:flex}}.site-nav a,.mobile-nav a{display:inline-flex;align-items:center;gap:.35rem;padding:.45rem .85rem;border-radius:var(--radius-full);font-size:.8125rem;font-weight:500;color:var(--color-text-muted);text-decoration:none;transition:background .15s,color .15s}.site-nav a:hover,.mobile-nav a:hover{background:var(--color-primary-soft);color:var(--color-primary)}.site-nav a.active,.mobile-nav a.active{background:var(--color-primary);color:#fff}.site-nav__logout{margin-left:auto}.main-content{flex:1;width:100%;max-width:880px;margin:0 auto;padding:1rem 1rem calc(var(--mobile-nav-h) + 1.25rem)}@media(min-width:900px){.main-content{padding-bottom:2.5rem}}@media(max-width:899px){.main-content{padding-left:.85rem;padding-right:.85rem}}.mobile-nav{position:fixed;bottom:0;left:0;right:0;z-index:50;display:grid;grid-template-columns:repeat(5,1fr);gap:.15rem;padding:.45rem .5rem calc(.45rem + env(safe-area-inset-bottom));background:#fffffff0;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-top:1px solid var(--color-border)}@media(min-width:900px){.mobile-nav{display:none}}.mobile-nav a{flex-direction:column;gap:.15rem;padding:.35rem .2rem;font-size:.625rem;border-radius:var(--radius-sm);text-align:center}.mobile-nav__icon{font-size:1rem;line-height:1}.auth-shell{min-height:100dvh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem 1.25rem;gap:2rem}.auth-shell__hero{text-align:center;max-width:520px}.auth-shell__eyebrow{margin:0;font-family:var(--font-display);font-size:.6875rem;letter-spacing:.2em;text-transform:uppercase;color:var(--color-primary);font-weight:700}.auth-shell__title{margin:.5rem 0 0;font-family:var(--font-display);font-size:clamp(1.6rem,5.5vw,2.2rem);font-weight:800;line-height:1.3;color:var(--color-text);letter-spacing:-.01em}.auth-shell__catchcopy{margin:.6rem 0 0;font-family:var(--font-display);font-size:clamp(.95rem,3vw,1.1rem);font-weight:600;color:var(--color-primary);letter-spacing:.08em}.auth-shell__subtitle{margin:.75rem 0 0;color:var(--color-text-muted);font-size:.875rem}.auth-shell__panel{width:100%;max-width:420px}.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:1.35rem 1.5rem;margin-bottom:1rem;box-shadow:var(--shadow-sm);transition:box-shadow .2s ease}.card:hover{box-shadow:var(--shadow-md)}.card--hero{background:linear-gradient(150deg,var(--color-surface) 0%,var(--color-primary-soft) 100%);border-color:#2563eb40}.card--featured{border:1.5px solid var(--color-primary);background:linear-gradient(180deg,var(--color-primary-soft) 0%,var(--color-surface) 55%)}.card--submitted{background:var(--color-success-bg);border-color:#15803d40}.section-grid{display:grid;gap:1rem}@media(min-width:640px){.section-grid--2{grid-template-columns:repeat(2,1fr)}.stat-grid{grid-template-columns:repeat(3,1fr)}}.stat-grid{display:grid;gap:.75rem;grid-template-columns:1fr}h1,h2,h3{font-family:var(--font-display);font-weight:700;line-height:1.35;color:var(--color-text);letter-spacing:-.01em}h1{font-size:1.6rem;margin:0 0 .75rem}h2{font-size:1.2rem;margin:0 0 .65rem}h3{font-size:1.05rem;margin:0 0 .5rem}.page-header{margin-bottom:1.25rem}.page-header__title{margin:0;font-size:1.45rem;font-weight:800}.page-header__desc{margin:.35rem 0 0;color:var(--color-text-muted);font-size:.875rem}.hero-banner{margin-bottom:1.25rem;padding:1.5rem 1.75rem;border-radius:var(--radius-lg);background:linear-gradient(135deg,#2563eb,#4f46e5);color:#fff;box-shadow:var(--shadow-md)}.hero-banner__catchcopy{margin:0;font-family:var(--font-display);font-size:clamp(1.1rem,4vw,1.4rem);font-weight:700;letter-spacing:.04em}.hero-banner__greeting{margin:.5rem 0 0;font-size:.875rem;opacity:.85}@media(max-width:639px){.hero-banner{padding:1.1rem 1rem;border-radius:var(--radius-md);margin-bottom:1rem}.hero-banner__catchcopy{font-size:1.05rem;line-height:1.45}.hero-banner__greeting{font-size:.8125rem}}.stat-card{display:flex;flex-direction:column;gap:.15rem;padding:1rem 1.15rem;border-radius:var(--radius-md);background:var(--color-surface);border:1px solid var(--color-border);box-shadow:var(--shadow-sm)}.stat-card--accent{background:var(--color-primary-soft);border-color:#2563eb4d}.stat-card__label{font-size:.6875rem;letter-spacing:.08em;text-transform:uppercase;color:var(--color-text-subtle);font-weight:600}.stat-card__value{font-family:var(--font-digit);font-size:1.8rem;font-weight:800;color:var(--color-primary);line-height:1.1;font-variant-numeric:tabular-nums}.stat-card__sub{font-size:.75rem;color:var(--color-text-muted)}.badge{display:inline-flex;align-items:center;padding:.2rem .65rem;border-radius:var(--radius-full);font-size:.6875rem;font-weight:600;letter-spacing:.03em;white-space:nowrap}.badge--default{background:var(--color-primary-soft);color:var(--color-primary)}.badge--success{background:var(--color-success-bg);color:var(--color-success)}.badge--warning{background:var(--color-warning-bg);color:var(--color-warning)}.badge--danger{background:var(--color-danger-bg);color:var(--color-danger)}.badge--muted{background:var(--color-bg-soft);color:var(--color-text-muted)}.badge--gold{background:var(--color-gold-light);color:var(--color-gold)}.podium{display:flex;align-items:flex-end;justify-content:center;gap:.65rem;margin:1rem 0;min-height:140px}.podium__item{display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:.85rem .75rem .65rem;border-radius:var(--radius-md) var(--radius-md) 0 0;border:1px solid var(--color-border);background:var(--color-surface-elevated);min-width:88px;text-align:center}.podium__item--1{order:2;min-height:120px;background:linear-gradient(180deg,var(--color-gold-light) 0%,var(--color-surface) 100%);border-color:var(--color-gold-muted)}.podium__item--2{order:1;min-height:95px}.podium__item--3{order:3;min-height:80px}.podium__item--self{outline:2px solid var(--color-primary);outline-offset:2px}.podium__rank{font-family:var(--font-digit);font-size:1.25rem;font-weight:800;color:var(--color-gold)}.podium__name{font-size:.8125rem;font-weight:600;word-break:break-all}.podium__points{font-size:.75rem;color:var(--color-text-muted);font-variant-numeric:tabular-nums}button,.btn{display:inline-flex;align-items:center;justify-content:center;gap:.35rem;padding:.6rem 1.25rem;border-radius:var(--radius-full);border:none;background:var(--color-primary);color:#fff;font-family:var(--font-body);font-size:.875rem;font-weight:600;cursor:pointer;transition:background .15s,transform .1s,box-shadow .15s;box-shadow:var(--shadow-sm);text-decoration:none}button:hover:not(:disabled),.btn:hover{background:var(--color-primary-dark);color:#fff}button:active:not(:disabled),.btn:active{transform:scale(.98)}button:disabled,.btn:disabled{opacity:.45;cursor:not-allowed}button.secondary,.btn--secondary{background:transparent;color:var(--color-text-muted);border:1px solid var(--color-border-strong);box-shadow:none}button.secondary:hover:not(:disabled),.btn--secondary:hover{background:var(--color-bg-soft);color:var(--color-text)}.btn--ghost{background:transparent;color:var(--color-primary);box-shadow:none;padding:.45rem .85rem}.btn--ghost:hover{background:var(--color-primary-soft);color:var(--color-primary)}.btn-group{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1rem}input,select,textarea{width:100%;padding:.65rem .85rem;border:1px solid var(--color-border-strong);border-radius:var(--radius-sm);font-family:var(--font-body);font-size:.9375rem;color:var(--color-text);background:var(--color-surface);transition:border-color .15s,box-shadow .15s}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #2563eb1f}label{display:block;margin-bottom:.35rem;font-size:.8125rem;font-weight:600;color:var(--color-text-muted);letter-spacing:.02em}.form-row{margin-bottom:1rem}.checkbox-label{display:flex;align-items:center;gap:.5rem;font-weight:500;cursor:pointer}.checkbox-label input{width:auto}.list-table{width:100%;border-collapse:separate;border-spacing:0;font-size:.875rem}.list-table th{text-align:left;padding:.65rem .75rem;font-size:.6875rem;letter-spacing:.06em;text-transform:uppercase;color:var(--color-text-subtle);font-weight:600;border-bottom:2px solid var(--color-border)}.list-table td{padding:.75rem;border-bottom:1px solid var(--color-border);vertical-align:middle}.list-table tbody tr:hover{background:var(--color-bg-soft)}.list-table tbody tr.row--self{background:var(--color-primary-soft);font-weight:600}.list-table tbody tr.row--self:hover{background:var(--color-primary-soft)}.table-wrap{overflow-x:auto;margin:0 -.25rem}.team-grid{display:grid;gap:.65rem;margin:1.25rem 0}@media(min-width:480px){.team-grid{grid-template-columns:repeat(2,1fr)}}.team-option{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.85rem 1rem;border:1.5px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;background:var(--color-surface);transition:border-color .15s,background .15s,box-shadow .15s}.team-option:hover{border-color:var(--color-primary)}.team-option:has(input:checked){border-color:var(--color-primary);background:var(--color-primary-soft);box-shadow:var(--shadow-sm)}.team-option input{position:absolute;opacity:0;width:0;height:0}.team-option__name{font-weight:600;font-size:.9375rem}.team-option__check{width:1.25rem;height:1.25rem;border-radius:50%;border:2px solid var(--color-border-strong);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:.7rem;color:transparent;transition:all .15s}.team-option:has(input:checked) .team-option__check{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.match-card__title{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem;margin-bottom:.85rem}.match-card__teams{font-family:var(--font-display);font-size:1.3rem;font-weight:700}.match-meta{display:grid;gap:.5rem;margin:0 0 1rem}@media(min-width:480px){.match-meta{grid-template-columns:repeat(2,1fr)}}.match-meta__item{display:flex;flex-direction:column;gap:.1rem;padding:.65rem .85rem;background:var(--color-bg-soft);border-radius:var(--radius-sm)}.match-meta__label{font-size:.625rem;letter-spacing:.08em;text-transform:uppercase;color:var(--color-text-subtle);font-weight:600}.match-meta__value{font-size:.875rem;font-weight:500}.match-meta__value--countdown{font-family:var(--font-digit);font-size:1.1rem;color:var(--color-primary);font-weight:700;font-variant-numeric:tabular-nums}.match-meta-list{margin:0 0 1rem;padding:0;list-style:none}.deadline-banner{background:var(--color-warning-bg);border:1px solid rgb(180 83 9 / 20%);border-radius:var(--radius-md);padding:1rem 1.15rem;margin-bottom:1.25rem}.deadline-banner p{margin:.25rem 0}.deadline-banner strong{color:var(--color-warning)}.scoreboard{display:flex;align-items:center;justify-content:center;gap:1rem;margin:1.25rem 0;padding:1.25rem;background:var(--color-bg-soft);border-radius:var(--radius-md);border:1px solid var(--color-border)}.scoreboard__team{flex:1;text-align:center}.scoreboard__team-name{display:block;font-size:.75rem;font-weight:600;color:var(--color-text-muted);margin-bottom:.35rem}.scoreboard__score{width:4rem;text-align:center;font-family:var(--font-digit);font-size:2rem;font-weight:800;padding:.35rem;border:2px solid var(--color-border-strong);border-radius:var(--radius-sm);background:var(--color-surface);font-variant-numeric:tabular-nums}.scoreboard__vs{font-family:var(--font-display);font-size:.9375rem;color:var(--color-text-subtle);font-weight:700}.match-tabs{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.25rem}.match-tab{padding:.5rem .85rem;border-radius:var(--radius-full);border:1px solid var(--color-border);background:var(--color-surface);font-size:.8125rem;font-weight:500;color:var(--color-text-muted);cursor:pointer;transition:all .15s;box-shadow:none}.match-tab:hover{border-color:var(--color-primary);color:var(--color-primary);background:var(--color-surface)}.match-tab--active{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.match-tab--active:hover{color:#fff;background:var(--color-primary)}.alert{padding:.75rem 1rem;border-radius:var(--radius-sm);font-size:.875rem;margin:.75rem 0}.alert--error{background:var(--color-danger-bg);color:var(--color-danger);border:1px solid rgb(220 38 38 / 20%)}.alert--success{background:var(--color-success-bg);color:var(--color-success);border:1px solid rgb(21 128 61 / 20%)}.alert--info{background:var(--color-primary-soft);color:var(--color-primary);border:1px solid rgb(37 99 235 / 15%)}.error{color:var(--color-danger);margin:.5rem 0;font-size:.875rem}.muted{color:var(--color-text-muted);font-size:.875rem}.success-text{color:var(--color-success);font-size:.875rem}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;padding:3rem 1rem;color:var(--color-text-muted)}.loading-spinner{width:2rem;height:2rem;border:2px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{text-align:center;padding:2rem 1rem;color:var(--color-text-muted)}.empty-state__icon{font-size:2rem;color:var(--color-border-strong);margin-bottom:.5rem}.empty-state__title{margin:0;font-weight:600;color:var(--color-text)}.empty-state__desc{margin:.35rem 0 0;font-size:.875rem}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#1d243373;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:200;padding:1rem;animation:fadeIn .2s ease}.modal{background:var(--color-surface);border-radius:var(--radius-lg);padding:1.5rem;max-width:420px;width:100%;border:1px solid var(--color-border);box-shadow:var(--shadow-lg);animation:slideUp .25s ease}.modal h2{margin-top:0}.modal__message{white-space:pre-line;color:var(--color-text-muted);line-height:1.6}.modal-actions{display:flex;gap:.5rem;margin-top:1.25rem}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.admin-section{margin-bottom:1rem}.admin-team-row{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center;padding:.65rem 0;border-bottom:1px solid var(--color-border)}.admin-team-row:last-child{border-bottom:none}.admin-team-row__name{min-width:100px;font-weight:600;flex:1}.admin-team-row input[type=number]{width:5rem}.submission-status{display:grid;gap:.65rem}.submission-status__item{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.85rem 1rem;background:var(--color-bg-soft);border-radius:var(--radius-md);border:1px solid var(--color-border)}.submission-status__label{font-weight:600;font-size:.875rem}.match-section{margin-bottom:1.25rem}.prediction-locked{color:var(--color-text-subtle);font-style:italic}.confirmed-pick{display:flex;align-items:center;gap:1rem;padding:1.25rem;background:var(--color-gold-light);border-radius:var(--radius-md);border:1px solid var(--color-gold-muted);margin:1rem 0}.confirmed-pick__flag{font-size:2rem}.confirmed-pick__name{font-family:var(--font-display);font-size:1.4rem;font-weight:700}.confirmed-pick__pts{font-size:.875rem;color:var(--color-gold);font-weight:600}.link-arrow{display:inline-flex;align-items:center;gap:.25rem;font-weight:600;font-size:.875rem}.link-arrow:after{content:"→";transition:transform .15s}.link-arrow:hover:after{transform:translate(3px)}@media(max-width:639px){.card{padding:1rem 1.1rem;border-radius:var(--radius-md)}.page-header__title{font-size:1.25rem}.match-card__title{flex-direction:column;align-items:flex-start}.match-card__teams{font-size:1.15rem}.submission-status__item{flex-direction:column;align-items:flex-start;gap:.5rem}.podium{gap:.4rem;min-height:120px}.podium__item{min-width:72px;padding:.65rem .5rem .5rem}.podium__name{font-size:.75rem}.scoreboard{flex-wrap:wrap;gap:.75rem;padding:1rem .75rem}.scoreboard__score{width:3.25rem;font-size:1.5rem}.match-tabs{gap:.35rem}.match-tab{font-size:.75rem;padding:.4rem .65rem}.auth-shell{padding:1.25rem 1rem;gap:1.25rem}.auth-shell__title{font-size:1.4rem}.auth-shell__catchcopy{font-size:.9rem}.btn-group{flex-direction:column}.btn-group .btn,.btn-group button{width:100%;text-align:center}.modal{padding:1.15rem}.modal-actions{flex-direction:column-reverse}.modal-actions button{width:100%}}
