:root{--color-bg: #f4f5f2;--color-bg-warm: #f7f1e8;--color-surface: #fffdf9;--color-surface-subtle: #f8faf9;--color-text: #1f2328;--color-muted: #667085;--color-border: rgba(31, 35, 40, .11);--color-primary: #b83a4b;--color-primary-dark: #8f2434;--color-secondary: #2c7a7b;--color-secondary-dark: #1e5b5f;--color-warning-bg: #fff7e6;--color-warning-border: rgba(148, 107, 45, .22);--shadow-card: 0 16px 42px rgba(31, 35, 40, .08);--shadow-soft: 0 8px 24px rgba(31, 35, 40, .06);--radius-card: 20px;--radius-control: 999px;color:var(--color-text);background:var(--color-bg);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}*{box-sizing:border-box}body{min-width:320px;min-height:100vh;margin:0}a{color:inherit;text-decoration:none}button,input,textarea{font:inherit}button{cursor:pointer}.app-shell{min-height:100vh;background:linear-gradient(180deg,rgba(184,58,75,.09),transparent 280px),var(--color-bg)}.admin-shell{background:linear-gradient(180deg,rgba(44,122,123,.1),transparent 280px),var(--color-bg)}.app-header,.app-main,.app-footer{width:min(100%,640px);margin:0 auto;padding-inline:20px}.app-header{display:flex;align-items:center;justify-content:space-between;gap:14px;padding-block:18px 10px}.brand{display:inline-flex;align-items:center;gap:10px;min-width:0}.brand-mark{display:grid;width:36px;height:36px;place-items:center;border-radius:11px;background:var(--color-primary);color:#fff;font-size:1.08rem;font-weight:800;box-shadow:0 8px 18px #b83a4b38}.brand strong,.brand small{display:block}.brand strong{color:var(--color-text);font-size:.98rem;line-height:1.1}.brand small{margin-top:2px;color:var(--color-muted);font-size:.76rem;line-height:1.1}.top-nav{display:inline-flex;align-items:center;gap:7px}.top-nav a{display:inline-flex;align-items:center;justify-content:center;gap:5px;min-height:38px;padding:0 12px;border:1px solid var(--color-border);border-radius:var(--radius-control);background:#fffdf9d1;color:#39434b;font-size:.88rem;font-weight:700;box-shadow:var(--shadow-soft)}.top-nav a:hover,.top-nav a:focus-visible{border-color:#b83a4b5c;color:var(--color-primary-dark);outline:none}.top-nav a.active{border-color:#b83a4b57;background:#fff3f3;color:var(--color-primary-dark)}.app-main{display:flex;flex-direction:column;gap:16px;padding-block:18px 38px}.app-footer{display:flex;align-items:center;justify-content:center;gap:8px;padding-bottom:26px;color:var(--color-muted);font-size:.86rem;text-align:center}.session-stack,.history-list,.admin-session-list,.recommendation-list{display:flex;flex-direction:column;gap:14px}.session-hero,.page-title,.admin-title{padding:14px 2px 4px;text-align:left}.eyebrow,.card-kicker{margin:0;color:var(--color-primary-dark);font-size:.74rem;font-weight:800;letter-spacing:0;line-height:1.2}.card-kicker{display:inline-flex;align-items:center;width:fit-content;min-height:24px;padding:0 10px;border-radius:var(--radius-control);background:#b83a4b17}.lesson-two .card-kicker,.admin-panel .card-kicker,.recommendation-panel .card-kicker{background:#2c7a7b17;color:var(--color-secondary-dark)}.session-hero h1,.page-title h1,.admin-title h1{max-width:560px;margin:8px 0;color:var(--color-text);font-size:clamp(1.72rem,7vw,2.5rem);line-height:1.15;letter-spacing:0;word-break:keep-all}.page-title h1,.admin-title h1{font-size:clamp(1.6rem,6vw,2.18rem)}.date-text{max-width:560px;margin:0;color:var(--color-muted);font-size:.98rem;font-weight:650;line-height:1.55;word-break:keep-all}.agenda-strip{display:grid;grid-template-columns:1fr;gap:8px;margin-top:16px}.agenda-strip span{display:flex;align-items:center;min-height:36px;padding:0 12px;border:1px solid var(--color-border);border-radius:var(--radius-control);background:#fffdf9b8;color:#3b464c;font-size:.88rem;font-weight:750}.study-card,.admin-panel,.empty-state,.status-panel{position:relative;overflow:hidden;border:1px solid var(--color-border);border-radius:var(--radius-card);background:var(--color-surface);box-shadow:var(--shadow-card)}.study-card:before,.admin-panel:before{position:absolute;inset:0 auto 0 0;width:5px;content:""}.study-card,.admin-panel{padding:22px}.lesson-one:before{background:var(--color-primary)}.lesson-two:before{background:var(--color-secondary)}.admin-panel:before{background:#2c7a7bb8}.memo-card{color:#3d4549;line-height:1.7;white-space:pre-wrap}.memo-card:before{background:#946b2d}.card-heading,.panel-heading{display:flex;align-items:flex-start;gap:12px;margin-bottom:15px;text-align:left}.card-heading h2,.panel-heading h2{margin:6px 0 0;color:var(--color-text);font-size:clamp(1.22rem,5vw,1.42rem);line-height:1.22;letter-spacing:0;word-break:keep-all}.icon-badge{display:grid;flex:0 0 auto;width:42px;height:42px;place-items:center;border-radius:14px;background:#b83a4b1a;color:var(--color-primary-dark)}.lesson-two .icon-badge,.admin-panel .icon-badge,.recommendation-panel .icon-badge{background:#2c7a7b1a;color:var(--color-secondary-dark)}.card-description{margin:-2px 0 18px;color:var(--color-muted);font-size:.98rem;line-height:1.64;text-align:left;word-break:keep-all}.topic-list{display:flex;flex-direction:column;gap:10px;margin:0;padding:0;list-style:none}.topic-list li{display:grid;grid-template-columns:34px 1fr;align-items:start;gap:11px;min-height:58px;padding:14px;border:1px solid rgba(44,122,123,.16);border-radius:16px;background:var(--color-surface-subtle);color:var(--color-text);font-size:1.02rem;font-weight:650;line-height:1.55;text-align:left;word-break:keep-all}.topic-number{display:grid;width:30px;height:30px;place-items:center;border-radius:999px;background:var(--color-secondary);color:#fff;font-size:.9rem;font-weight:800}.primary-button,.secondary-button,.text-link{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:48px;border-radius:var(--radius-control);font-size:.98rem;font-weight:750;line-height:1;transition:background-color .12s ease,border-color .12s ease,color .12s ease,transform .12s ease}.primary-button,.secondary-button{width:fit-content;border:1px solid transparent;padding:0 18px}.primary-button{background:var(--color-primary);color:#fff;box-shadow:0 12px 26px #b83a4b38}.primary-button:hover,.primary-button:focus-visible{background:var(--color-primary-dark);outline:none;transform:translateY(-1px)}.nhk-button{width:100%;min-height:54px;font-size:1rem}.secondary-button{border-color:var(--color-border);background:#fffdf9db;color:#354047;box-shadow:var(--shadow-soft)}.secondary-button:hover,.secondary-button:focus-visible{border-color:#2c7a7b47;background:#f7fbfa;color:var(--color-secondary-dark);outline:none}.primary-button:disabled,.secondary-button:disabled{cursor:not-allowed;opacity:.58;transform:none}.full-width-button{width:100%}.text-link{align-self:flex-start;min-height:38px;color:#435057;font-weight:800}.text-link:hover,.text-link:focus-visible{color:var(--color-primary-dark);outline:none}.empty-state,.status-panel{display:grid;justify-items:start;min-height:0;padding:22px;text-align:left}.status-panel{gap:8px}.empty-state h1,.empty-state h2,.empty-state p,.status-panel h1,.status-panel h2,.status-panel p{max-width:440px;margin:0}.status-panel h1,.empty-state h1,.empty-state h2{color:var(--color-text);font-size:1.1rem;line-height:1.35;word-break:keep-all}.empty-state p,.status-body{color:var(--color-muted);font-size:.95rem;line-height:1.62}.empty-state svg,.status-panel svg{color:var(--color-primary)}.status-loading svg{color:var(--color-secondary)}.status-api svg{color:#946b2d}.topic-empty{border:1px solid rgba(44,122,123,.16);border-radius:16px;background:var(--color-surface-subtle);padding:16px;color:var(--color-muted);line-height:1.65;text-align:left}.topic-empty strong{display:block;color:var(--color-text);font-size:1.02rem;line-height:1.4;word-break:keep-all}.topic-empty p{margin:6px 0 0;font-size:.95rem}.inline-alert{border:1px solid var(--color-warning-border);border-radius:16px;background:var(--color-warning-bg);color:#5b5146;padding:13px 15px;font-size:.9rem;line-height:1.52;text-align:left}.inline-alert strong{display:block;color:#6c4a17;font-size:.92rem}.inline-alert p{margin:4px 0 0}.history-item,.admin-session-item{display:flex;align-items:center;justify-content:space-between;gap:14px;width:100%;min-height:78px;border:1px solid var(--color-border);border-radius:18px;background:var(--color-surface);padding:17px 18px;color:var(--color-text);text-align:left;box-shadow:var(--shadow-soft)}.history-item:hover,.history-item:focus-visible,.admin-session-item:hover,.admin-session-item:focus-visible{border-color:#2c7a7b3d;outline:none}.history-item strong,.history-item small,.admin-session-item strong,.admin-session-item small{display:block}.history-item strong,.admin-session-item strong{font-size:1.02rem;line-height:1.36;word-break:keep-all}.history-item small,.admin-session-item small{margin-top:5px;color:var(--color-muted);font-size:.88rem}.auth-panel label,.admin-form label{display:flex;flex-direction:column;gap:8px;color:#35434a;font-size:.92rem;font-weight:750;text-align:left}input,textarea{width:100%;border:1px solid var(--color-border);border-radius:14px;background:#fff;color:var(--color-text);padding:13px 14px;font-size:1rem}input:focus,textarea:focus{border-color:#2c7a7b6b;box-shadow:0 0 0 4px #2c7a7b1a;outline:none}textarea{resize:vertical}.form-grid{display:grid;grid-template-columns:1fr;gap:14px}.form-actions{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:10px;margin-top:18px}.muted-text,.form-message{color:var(--color-muted);font-size:.94rem;line-height:1.62}.form-message{margin:14px 0 0;color:var(--color-secondary-dark);font-weight:750}.recommendation-panel .secondary-button{margin-top:4px}.recommendation-item{border:1px solid rgba(44,122,123,.16);border-radius:16px;background:var(--color-surface-subtle);padding:15px;text-align:left}.recommendation-item p,.recommendation-item strong,.recommendation-item small{display:block;margin:0}.recommendation-item p{color:var(--color-text);line-height:1.55}.recommendation-item strong{margin-top:8px;color:var(--color-secondary-dark);line-height:1.5}.recommendation-item small{margin-top:8px;color:var(--color-muted)}@media (min-width: 620px){.app-header,.app-main,.app-footer{padding-inline:26px}.agenda-strip,.form-grid{grid-template-columns:1fr 1fr}.wide-field{grid-column:1 / -1}}@media (max-width: 430px){.app-header,.app-main,.app-footer{padding-inline:16px}.top-nav a{min-height:36px;padding:0 10px;font-size:.82rem}.study-card,.admin-panel,.status-panel{padding:20px}.primary-button,.secondary-button{width:100%}}
