:root{--color-primary: #C62828;--color-primary-dark: #8E0000;--color-accent: #F9A825;--color-text-on-primary: #fff;--color-text: #333;--color-border: #ddd;--color-border-light: #f0f0f0;--color-muted: #888}*,*:before,*:after{box-sizing:border-box}body{margin:0;font-family:sans-serif;color:var(--color-text)}a{color:inherit;text-decoration:none}button{cursor:pointer;border:1px solid #d0d0d0;background:#fff;border-radius:6px;padding:.35rem .8rem;font-size:.875rem;color:var(--color-text);line-height:1.4;transition:background .12s,border-color .12s}button:hover:not(:disabled){background:#f4f4f4;border-color:#aaa}button:active:not(:disabled){background:#eaeaea}button:disabled{opacity:.4;cursor:default}.header{display:flex;justify-content:space-between;align-items:center;padding:.75rem 2rem;background-color:var(--color-primary);color:var(--color-text-on-primary);position:sticky;top:0;z-index:100}.header-nav{display:flex;gap:1.5rem;align-items:center}.header-brand{color:var(--color-accent);font-weight:700;font-size:.95rem;letter-spacing:.04em;white-space:nowrap}.header-right{display:flex;gap:1rem;align-items:center;font-size:.875rem}.header-nickname{color:var(--color-text-on-primary);text-decoration:underline;text-decoration-color:#ffffff80;text-underline-offset:3px;font-size:.875rem}.header-logout{background:var(--color-primary-dark);color:var(--color-text-on-primary);border:none;padding:.3rem .75rem;border-radius:4px}.page{padding:2rem}.month-nav{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.month-nav button{border-color:var(--color-primary);color:var(--color-primary)}.month-nav button:hover:not(:disabled){background:#fef2f2;border-color:var(--color-primary-dark);color:var(--color-primary-dark)}.month-nav button:disabled{border-color:#ddd;color:#bbb}.tab-bar{display:flex;margin-bottom:1.5rem;border-bottom:2px solid var(--color-accent)}.tab-btn{padding:.5rem 1.25rem;border:none;background:transparent;color:var(--color-text);font-size:1rem;cursor:pointer}.tab-btn.active,.tab-btn.active:hover{background:var(--color-primary);color:#fff;font-weight:700}.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}table{border-collapse:collapse;width:100%}h2{color:var(--color-primary);text-align:center}th{padding:.5rem;border-bottom:2px solid var(--color-accent);text-align:left;font-weight:600;white-space:nowrap}td{padding:.5rem;border-bottom:1px solid var(--color-border-light)}.td-center{text-align:center}.td-empty{padding:1rem;text-align:center;color:var(--color-muted)}.table-yearly th,.table-yearly td{padding:.2rem .25rem;font-size:.78rem;white-space:nowrap}.table-yearly th:first-child,.table-yearly td:first-child{width:1px;padding:.2rem .1rem;text-align:center}.auth-page{display:flex;justify-content:center;padding-top:3rem}.auth-form{display:flex;flex-direction:column;gap:.75rem;width:300px}.auth-form h2{margin:0}fieldset{border:1px solid var(--color-border);border-radius:6px;padding:.75rem;display:flex;flex-direction:column;gap:.5rem}legend{font-size:.8rem;color:var(--color-muted);padding:0 .25rem}input{padding:.4rem .5rem;border:1px solid var(--color-border);border-radius:4px;font-size:1rem;width:100%}.form-error{color:red;margin:0;font-size:.875rem}.btn-row{display:flex;gap:.5rem;flex-wrap:wrap}.score-btn-checkin{padding:.75rem 2rem;font-size:1.1rem;font-weight:700;background:var(--color-primary);color:#fff;border:none;border-radius:8px}.score-btn-checkin:hover:not(:disabled){background:var(--color-primary-dark)}.score-row{display:flex;align-items:center;gap:.75rem}.score-label{font-size:1.1rem;font-weight:700;width:1.5rem;color:var(--color-text)}.score-btn{width:52px;height:52px;font-size:1.6rem;font-weight:700;border-radius:50%;display:flex;align-items:center;justify-content:center;padding:0;line-height:1}.score-btn-plus{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.score-btn-plus:hover:not(:disabled){background:var(--color-primary-dark);border-color:var(--color-primary-dark)}.score-btn-minus{background:#fff;color:#888;border-color:#ccc}.score-count{display:inline-flex;align-items:center;gap:6px;min-width:5rem;font-size:1rem}.score-count em{font-style:normal;font-size:1.1rem;font-weight:700;color:var(--color-text)}@media (max-width: 600px){.header{padding:.6rem 1rem}.header-nav{gap:.75rem;font-size:.9rem}.header-right{gap:.5rem}.header-nickname{font-size:.8rem}.header-logout{padding:.25rem .5rem;font-size:.8rem}.page{padding:1rem .75rem}.auth-page{padding-top:1.5rem;padding-left:.75rem;padding-right:.75rem;align-items:flex-start}.auth-form{width:100%}th,td{padding:.35rem .4rem;font-size:.875rem}.tab-btn{padding:.4rem .75rem;font-size:.875rem}.month-nav button{font-size:.8rem}}
