﻿@import"https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;500;700&family=Noto+Serif+JP:wght@400;700&display=swap";:root{--primary-red: #d92b2b;--ink-black: #1a1a1b;--official-gray: #4a4a4a;--paper-bg: #ffffff;--header-bg: #e2e1d9;--body-bg: #d1d5db;--text-primary: #0f172a;--text-secondary: #64748b;--text-muted: #94a3b8;--border-light: #e2e8f0;--border-default: #cbd5e1;--border-dark: #94a3b8;--success: #10b981;--warning: #f59e0b;--error: #ef4444}*,*::before,*::after{box-sizing:border-box}*{margin:0;padding:0}html{height:100%;font-size:16px}body{min-height:100%;line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}img,picture,video,canvas,svg{display:block;max-width:100%}input,button,textarea,select{font:inherit}button{cursor:pointer}p,h1,h2,h3,h4,h5,h6{overflow-wrap:break-word}html{font-size:14px}body{font-family:"Noto Sans JP",sans-serif;font-weight:400;color:var(--text-primary)}.trix-content{font-family:"Noto Sans JP",sans-serif;line-height:1.7}.learning-layout{font-family:"Noto Serif JP",serif;background-color:var(--body-bg);color:var(--ink-black)}@media(max-width: 767px){.learning-layout{padding-top:160px}}.blank-input{border-bottom:2px solid var(--ink-black);background:rgba(0,0,0,0);text-align:center;transition:all .2s ease;outline:none;color:#1e40af;font-weight:700;padding:4px 8px;border-radius:0;font-family:"Noto Serif JP",serif;font-size:1.75rem;line-height:1.5}.blank-input:focus{background-color:rgba(0,0,0,.03);outline:2px solid var(--primary-red);outline-offset:2px}.blank-input.correct{border-bottom-color:rgba(0,0,0,0);color:var(--primary-red);font-family:"Noto Serif JP",serif;cursor:default}.blank-input.incorrect{background-color:rgba(239,68,68,.1);border-bottom-color:var(--error)}.blank-input.blank-input--review{display:inline;padding:4px 8px;border:none;border-bottom:2px solid var(--ink-black);background:rgba(0,0,0,0);white-space:normal;word-wrap:break-word;overflow-wrap:break-word}.blank-input.blank-input--review.correct{border-bottom-color:rgba(0,0,0,0);color:var(--primary-red);background:rgba(0,0,0,0)}.blank-input.blank-input--review.incorrect{background-color:rgba(239,68,68,.1);border-bottom-color:var(--error)}.blank-input.blank-input--review.unanswered{background-color:rgba(156,163,175,.1);border-bottom-color:#9ca3af;color:#6b7280}.app-header{background:linear-gradient(135deg, #1e40af 0%, #0b1f3a 100%);padding:12px 0;border-bottom:1px solid hsla(0,0%,100%,.08);box-shadow:0 6px 16px rgba(15,23,42,.25);position:sticky;top:0;z-index:1000}.app-header__container{max-width:980px;margin:0 auto;padding:0 .25rem}@media(min-width: 1024px){.app-header__container{padding:0 .5rem}}.app-header__container{display:flex;align-items:center;gap:24px}.app-header__brand{flex:0 0 auto}.app-header__logo{display:inline-flex;align-items:center;text-decoration:none}.app-header__logo:hover{opacity:.9}.app-header__logo-text{font-size:1.6rem;font-weight:800;color:#fff;font-family:"Noto Serif JP",serif}.app-header__logo-image{height:36px;width:auto;max-width:180px;display:block}.app-header__menu-button{display:none;width:42px;height:42px;align-items:center;justify-content:center;flex-direction:column;gap:5px;border-radius:999px;border:1px solid hsla(0,0%,100%,.2);background:hsla(0,0%,100%,.12);cursor:pointer;transition:background-color .2s ease,border-color .2s ease}.app-header__menu-button span{display:block;width:22px;height:3px;background:#fff;border-radius:999px;box-shadow:0 2px 6px rgba(15,23,42,.35)}.app-header__menu-button:hover{background:hsla(0,0%,100%,.2);border-color:hsla(0,0%,100%,.35)}.app-header__menu{display:flex;align-items:center;gap:24px;flex:1}.app-header__nav{display:flex;gap:8px;flex:1}.app-header__nav-link{padding:8px 16px;color:hsla(0,0%,100%,.85);text-decoration:none;border-radius:6px;font-weight:600;transition:all .2s ease}.app-header__nav-link:hover{background:hsla(0,0%,100%,.1);color:#fff}.app-header__nav-link--active{background:hsla(0,0%,100%,.18);color:#fff;font-weight:700}.app-header__controls{flex:0 0 auto}.app-header__user{flex:0 0 auto}.app-header__user-info{display:flex;align-items:center;gap:12px}.app-header__user-email{color:hsla(0,0%,100%,.75);font-size:.9rem}.app-header__user-menu{position:relative}.app-header__user-trigger{border:1px solid hsla(0,0%,100%,.2);background:hsla(0,0%,100%,.08);color:hsla(0,0%,100%,.9);padding:6px 12px;border-radius:999px;display:inline-flex;align-items:center;gap:8px;font-size:.9rem;font-weight:600;cursor:pointer;transition:background-color .2s ease,border-color .2s ease}.app-header__user-trigger:hover{background:hsla(0,0%,100%,.16);border-color:hsla(0,0%,100%,.35)}.app-header__user-caret{width:8px;height:8px;border-right:2px solid currentColor;border-bottom:2px solid currentColor;transform:rotate(45deg);margin-bottom:2px}.app-header__user-dropdown{position:absolute;right:0;top:100%;margin-top:6px;background:#fff;border-radius:12px;border:1px solid #e2e8f0;box-shadow:0 16px 28px rgba(15,23,42,.18);padding:8px;display:none;min-width:180px;z-index:1001}.app-header__user-dropdown::before{content:"";position:absolute;top:-6px;left:0;right:0;height:6px}.app-header__user-item{display:block;padding:8px 12px;border-radius:8px;color:#0f172a;text-decoration:none;font-weight:600;transition:background-color .2s ease,color .2s ease}.app-header__user-item:hover{background:#eff6ff;color:#1e40af}.app-header__user-item--danger{color:#b91c1c}.app-header__user-item--danger:hover{background:#fee2e2;color:#b91c1c}.app-header__user-menu:hover .app-header__user-dropdown,.app-header__user-menu:focus-within .app-header__user-dropdown,.app-header__user-trigger:hover+.app-header__user-dropdown,.app-header__user-dropdown:hover{display:block}.app-header__logout{color:hsla(0,0%,100%,.9);text-decoration:none;padding:6px 12px;border-radius:999px;font-size:.9rem;transition:background-color .2s ease}.app-header__logout:hover{background:hsla(0,0%,100%,.12);color:#fff}.app-header__auth-links{display:flex;gap:8px}.app-header__auth-link{padding:8px 16px;color:hsla(0,0%,100%,.9);text-decoration:none;border-radius:6px;font-weight:600;transition:all .2s ease;border:1px solid rgba(0,0,0,0)}.app-header__auth-link:hover{background:hsla(0,0%,100%,.1);color:#fff}.app-header__auth-link--primary{background:hsla(0,0%,100%,.2);color:#fff;border-color:hsla(0,0%,100%,.3)}.app-header__auth-link--primary:hover{background:hsla(0,0%,100%,.3)}.app-header__backdrop{display:none}@media(max-width: 768px){.app-header__container{gap:12px}.app-header__menu-button{display:inline-flex;margin-left:auto}.app-header__menu{display:none;position:fixed;top:0;right:0;height:100vh;width:min(78vw,320px);flex-direction:column;align-items:stretch;justify-content:flex-start;gap:16px;padding:90px 20px 24px;background:#f6f8ff;background-image:radial-gradient(8px 8px at 18% 20%, rgba(59, 130, 246, 0.08) 0 60%, rgba(246, 248, 255, 0) 62%),radial-gradient(10px 10px at 78% 28%, rgba(14, 165, 233, 0.06) 0 60%, rgba(246, 248, 255, 0) 62%),radial-gradient(12px 12px at 28% 76%, rgba(59, 130, 246, 0.05) 0 60%, rgba(246, 248, 255, 0) 62%),linear-gradient(145deg, rgba(226, 232, 255, 0.9), rgba(255, 255, 255, 0.95));box-shadow:-16px 0 30px rgba(15,23,42,.4);transform:translateX(100%);transition:transform .2s ease;z-index:1100}.app-header.app-header--menu-open .app-header__menu{display:flex;transform:translateX(0)}.app-header__backdrop{display:block;position:fixed;inset:0;background:rgba(15,23,42,.45);opacity:0;pointer-events:none;transition:opacity .2s ease;z-index:1050}.app-header.app-header--menu-open .app-header__backdrop{opacity:1;pointer-events:auto}.app-header__nav{flex-direction:column;gap:6px}.app-header__nav-link{padding:10px 12px;font-size:.95rem;color:#0b1f3a;background:hsla(0,0%,100%,.75);border:1px solid rgba(148,163,184,.25)}.app-header__nav-link:hover{background:rgba(226,232,255,.9);color:#0b1f3a}.app-header__nav-link--active{background:rgba(30,64,175,.12);color:#1e3a8a;border-color:rgba(30,64,175,.35)}.app-header__user-email{display:none}.app-header__auth-links{flex-direction:column;align-items:stretch}.app-header__auth-link{width:100%;text-align:center;color:#0b1f3a;background:hsla(0,0%,100%,.8);border-color:rgba(148,163,184,.3)}.app-header__auth-link:hover{background:rgba(226,232,255,.95);color:#0b1f3a}.app-header__auth-link--primary{background:rgba(30,64,175,.12);color:#1e3a8a;border-color:rgba(30,64,175,.35)}.app-header__auth-link--primary:hover{background:rgba(30,64,175,.18)}}.app-main{min-height:80vh}.static-page{padding:2rem 0 3rem}.static-page__container{max-width:980px;margin:0 auto;padding:0 .25rem}@media(min-width: 1024px){.static-page__container{padding:0 .5rem}}.static-card{background:#fff;border-radius:16px;border:1px solid #e2e8f0;box-shadow:0 16px 32px rgba(15,23,42,.08);padding:32px}@media(max-width: 767px){.static-card{padding:24px}}.static-card__title{font-size:2rem;font-weight:800;color:#0b1f3a;margin-bottom:12px}.static-card__lead{color:#64748b;margin-bottom:20px}.static-faq{display:flex;flex-direction:column;gap:18px}.static-faq__item{border-bottom:1px solid #e2e8f0;padding-bottom:16px}.static-faq__question{font-size:1.1rem;font-weight:700;color:#1e3a8a;margin-bottom:8px}.static-faq__answer{color:#475569}.static-form{display:flex;flex-direction:column;gap:16px}.static-form__field{display:flex;flex-direction:column;gap:8px}.static-form__label{font-weight:600;color:#1f2937}.static-form__input,.static-form__textarea{border:1px solid #e2e8f0;border-radius:10px;padding:12px 14px;font-size:1rem;transition:border-color .2s ease,box-shadow .2s ease}.static-form__input:focus,.static-form__textarea:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px rgba(59,130,246,.12)}.static-form__submit{align-self:flex-start}.app-footer{background:linear-gradient(180deg, #1e40af 0%, #0b1f3a 100%);color:hsla(0,0%,100%,.85);padding:2rem 0 1.5rem;margin-top:auto;border-top:1px solid hsla(0,0%,100%,.08)}.app-footer__container{max-width:980px;margin:0 auto;padding:0 .25rem}@media(min-width: 1024px){.app-footer__container{padding:0 .5rem}}.app-footer__container{text-align:left;display:flex;flex-direction:column;gap:20px}.app-footer__content{display:grid;grid-template-columns:minmax(240px, 1.4fr) minmax(200px, 1fr);gap:32px}@media(max-width: 767px){.app-footer__content{grid-template-columns:1fr}}.app-footer__brand{display:flex;flex-direction:column;gap:12px}.app-footer__title{font-size:1.1rem;font-weight:700;color:#fff}.app-footer__lead{color:hsla(0,0%,100%,.7);max-width:380px}.app-footer__nav{display:grid;grid-template-columns:repeat(2, minmax(140px, 1fr));gap:20px;font-weight:600;font-size:.95rem}@media(max-width: 767px){.app-footer__nav{grid-template-columns:1fr}}.app-footer__nav-group{display:flex;flex-direction:column;gap:10px}.app-footer__nav-title{font-size:.85rem;text-transform:uppercase;letter-spacing:.16em;color:hsla(0,0%,100%,.6)}.app-footer__link{color:hsla(0,0%,100%,.85);text-decoration:none;transition:color .2s ease,text-decoration-color .2s ease;width:fit-content}.app-footer__link:hover{color:#fff;text-decoration:underline;text-decoration-color:hsla(0,0%,100%,.7)}.app-footer__copyright{font-size:.95rem;letter-spacing:.02em;border-top:1px solid hsla(0,0%,100%,.08);padding-top:16px}.learning-page{min-height:100vh;background:linear-gradient(135deg, #f8fafc 0%, #e2e8f0 100%)}.learning-header{background:#f8fafc;border-bottom:1px solid #e2e8f0;padding:20px 0;position:sticky;top:0;z-index:10;box-shadow:0 8px 18px rgba(15,23,42,.08);overflow:hidden}.learning-header::before{content:"";position:absolute;top:-30px;right:-120px;width:240px;height:160px;background:linear-gradient(135deg, rgba(59, 130, 246, 0.2), rgba(14, 165, 233, 0.04));transform:skewX(-12deg);border-radius:28px;z-index:0}.learning-header::after{content:"";position:absolute;bottom:-70px;left:-80px;width:200px;height:200px;border-radius:999px;background:radial-gradient(circle at 30% 30%, rgba(14, 165, 233, 0.16), rgba(59, 130, 246, 0.02) 65%);z-index:0}.learning-header__content{max-width:980px;margin:0 auto;padding:0 .25rem}@media(min-width: 1024px){.learning-header__content{padding:0 .5rem}}.learning-header__content{display:flex;align-items:center;justify-content:space-between;gap:20px;position:relative;z-index:1}@media(max-width: 767px){.learning-header__content{flex-direction:column;gap:12px}}.learning-header__left{flex:1}.learning-header__back{color:#6b7280;text-decoration:none;font-weight:500;font-size:.875rem}.learning-header__back:hover{color:#374151}.learning-header__center{flex:2;text-align:center}.learning-header__select{background:#fff;border:2px solid #e5e7eb;border-radius:8px;padding:8px 16px;font-size:.875rem;min-width:280px}.learning-header__select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px rgba(59,130,246,.1)}@media(max-width: 767px){.learning-header__select{min-width:100%}}.learning-header__right{flex:1;display:flex;align-items:center;justify-content:flex-end;gap:16px}@media(max-width: 767px){.learning-header__right{justify-content:center;width:100%}}.learning-header__progress{font-size:.875rem;color:#6b7280;font-weight:500}.learning-header__restart{background:#f3f4f6;color:#6b7280;border:none;padding:6px 12px;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease}.learning-header__restart:hover{background:#e5e7eb;color:#374151}.learning-main{max-width:980px;margin:0 auto;padding:0 .25rem}@media(min-width: 1024px){.learning-main{padding:0 .5rem}}.learning-main{padding-top:40px;padding-bottom:40px}.learning-content{background:#fff;border-radius:12px;padding:40px;box-shadow:0 10px 25px rgba(0,0,0,.1);border:1px solid #e5e7eb}@media(max-width: 767px){.learning-content{padding:24px}}.learning-content .chapter-title{font-size:1.875rem;font-weight:700;color:#1e3a8a;margin-bottom:32px;padding-bottom:16px;border-bottom:2px solid #3b82f6;font-family:"Noto Serif JP",serif}@media(max-width: 767px){.learning-content .chapter-title{font-size:1.5rem;margin-bottom:24px}}.learning-show__content{max-width:980px;margin:0 auto;padding:0 .25rem}@media(min-width: 1024px){.learning-show__content{padding:0 .5rem}}.learning-show__content{padding-bottom:4rem}.learning-show__document{background-color:var(--paper-bg);box-shadow:0 20px 25px -5px rgba(0,0,0,.2);background-image:radial-gradient(#e5e1d8 1px, transparent 1px);background-size:20px 20px;min-height:1100px;border:1px solid var(--border-default);margin-top:1.5rem;border-radius:.125rem;padding:4rem 3rem;position:relative;overflow:hidden}@media(max-width: 767px){.learning-show__document{padding:2rem 1.5rem;margin-top:1rem}}.learning-show__document::before{content:"鑑定基準原案";position:absolute;top:50%;left:50%;transform:translate(-50%, -50%) rotate(-30deg);pointer-events:none;opacity:.02;font-size:6rem;font-weight:700;white-space:nowrap;user-select:none;z-index:1}@media(max-width: 767px){.learning-show__document::before{font-size:4rem}}.learning-show__document .chapter-content{position:relative;z-index:2;line-height:2;font-size:1.25rem}@media(max-width: 767px){.learning-show__document .chapter-content{font-size:1.125rem;line-height:1.75}}.learning-show__document .chapter-content .chapter-title{font-size:2.25rem;font-weight:700;color:var(--text-primary);border-bottom:2px solid var(--text-primary);display:inline-block;padding-bottom:.5rem;margin-bottom:2rem}@media(max-width: 767px){.learning-show__document .chapter-content .chapter-title{font-size:1.75rem}}.learning-show__document .chapter-content p{margin-bottom:1.5rem;line-height:1.75}.learning-show__document .chapter-content h1,.learning-show__document .chapter-content h2,.learning-show__document .chapter-content h3,.learning-show__document .chapter-content h4,.learning-show__document .chapter-content h5,.learning-show__document .chapter-content h6{font-family:"Noto Serif JP",serif;font-weight:700;margin-top:2rem;margin-bottom:1rem;color:var(--ink-black)}.learning-show__document .chapter-content h2{font-size:1.75rem;border-bottom:2px solid var(--ink-black);padding-bottom:.5rem;margin-bottom:1.5rem}.learning-show__document .chapter-content h3{font-size:1.5rem;margin-bottom:1rem}.learning-show__document .chapter-content ul{margin:1rem 0;padding-left:2rem;list-style:none}.learning-show__document .chapter-content ul li{position:relative;margin-bottom:.5rem;line-height:1.75}.learning-show__document .chapter-content ol{margin:1rem 0;padding-left:2rem;counter-reset:list-counter}.learning-show__document .chapter-content ol li{position:relative;margin-bottom:.5rem;padding-left:2rem;line-height:1.75;counter-increment:list-counter}.learning-show__document .chapter-content ol li::before{content:"(" counter(list-counter) ")";position:absolute;left:0;color:var(--primary-red);font-weight:700;font-family:"Noto Sans JP",sans-serif}.learning-show__document .chapter-content blockquote{margin:2rem 0;padding:1.5rem 2rem;border-left:4px solid var(--primary-red);background:rgba(253,250,242,.8);font-style:italic;position:relative}.learning-show__document .chapter-content blockquote::before{content:"※";position:absolute;top:-0.5rem;left:-0.5rem;background:var(--primary-red);color:#fff;width:1.5rem;height:1.5rem;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1rem;font-weight:700}.learning-show__document .chapter-content strong,.learning-show__document .chapter-content b{font-weight:700;color:var(--ink-black);font-family:"Noto Serif JP",serif}.learning-show__document .chapter-content em,.learning-show__document .chapter-content i{font-style:italic;color:var(--official-gray)}.kizyun-index__main{max-width:980px;margin:0 auto;padding:0 .25rem}@media(min-width: 1024px){.kizyun-index__main{padding:0 .5rem}}.kizyun-index__main{padding-top:60px;padding-bottom:60px}@media(max-width: 767px){.kizyun-index__main{padding-top:40px;padding-bottom:40px}}.kizyun-index__cards{display:grid;grid-template-columns:1fr 1fr;gap:40px;max-width:1200px;margin:0 auto}@media(max-width: 767px){.kizyun-index__cards{grid-template-columns:1fr;gap:30px}}.kizyun-index__card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:32px;box-shadow:0 1px 3px rgba(0,0,0,.1);transition:all .3s ease}.kizyun-index__card:hover{box-shadow:0 10px 25px rgba(0,0,0,.15);transform:translateY(-2px)}.kizyun-index__card--available{border-color:#3b82f6;box-shadow:0 1px 3px rgba(59,130,246,.2)}.kizyun-index__card--available:hover{box-shadow:0 10px 25px rgba(59,130,246,.3)}.kizyun-index__card--disabled{background:#f8fafc;border-color:#e2e8f0;opacity:.7}.kizyun-index__card--disabled:hover{transform:none;box-shadow:0 1px 3px rgba(0,0,0,.1)}.kizyun-index__card-header{display:flex;align-items:center;gap:16px;margin-bottom:24px}.kizyun-index__card-icon{width:64px;height:64px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:28px;font-weight:700}.kizyun-index__card-icon--primary{background:linear-gradient(135deg, #3b82f6, #1e3a8a);color:#fff}.kizyun-index__card-icon--disabled{background:#e2e8f0;color:#94a3b8}.kizyun-index__card-title{font-size:1.875rem;font-weight:700;color:#1f2937;margin-bottom:4px}.kizyun-index__card-subtitle{color:#6b7280;font-size:.875rem}.kizyun-index__card-description{color:#374151;line-height:1.6;margin-bottom:32px}.kizyun-index__levels{display:flex;flex-direction:column;gap:16px}.kizyun-index__level{border:1px solid #e5e7eb;border-radius:8px;padding:24px;background:#fff;transition:all .3s ease}.kizyun-index__level--available{border-color:#3b82f6;background:linear-gradient(135deg, #f0f8ff, #ffffff)}.kizyun-index__level--available:hover{box-shadow:0 4px 12px rgba(59,130,246,.15)}.kizyun-index__level--disabled{background:#f8fafc;border-color:#e2e8f0}.kizyun-index__level-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}@media(max-width: 767px){.kizyun-index__level-header{flex-direction:column;align-items:flex-start;gap:16px}}.kizyun-index__level-info{flex:1}.kizyun-index__level-title{font-size:1.125rem;font-weight:700;color:#1f2937;margin-bottom:4px}.kizyun-index__level-description{color:#6b7280;font-size:.875rem;margin-bottom:8px}.kizyun-index__level-stats{display:flex;gap:16px;font-size:.75rem;color:#9ca3af}@media(max-width: 767px){.kizyun-index__level-stats{flex-wrap:wrap;gap:12px}}.kizyun-index__level-actions{display:flex;flex-direction:column;gap:8px}.kizyun-index__btn{padding:12px 24px;border-radius:6px;font-weight:700;text-align:center;text-decoration:none;transition:all .3s ease;border:none;cursor:pointer;font-size:.875rem}.kizyun-index__btn--primary{background:linear-gradient(135deg, #3b82f6, #1e3a8a);color:#fff}.kizyun-index__btn--primary:hover{background:linear-gradient(135deg, #2563eb, #1e40af);transform:translateY(-1px);box-shadow:0 4px 8px rgba(59,130,246,.3)}.kizyun-index__btn--secondary{background:#f1f5f9;color:#475569}.kizyun-index__btn--secondary:hover{background:#e2e8f0}.kizyun-index__btn--disabled{background:#e2e8f0;color:#9ca3af;cursor:not-allowed}.kizyun-index__btn--disabled:hover{transform:none;box-shadow:none}.kizyun-index__chapters{display:none;margin-top:16px;padding-top:16px;border-top:1px solid #e5e7eb}.kizyun-index__chapters--visible{display:block}.kizyun-index__chapter{display:flex;justify-content:space-between;align-items:center;padding:16px;background:#fff;border:1px solid #e5e7eb;border-radius:6px;margin-bottom:8px;text-decoration:none;transition:all .2s ease}.kizyun-index__chapter:hover{border-color:#3b82f6;box-shadow:0 2px 4px rgba(59,130,246,.1)}.kizyun-index__chapter-info{display:flex;flex-direction:column}.kizyun-index__chapter-number{font-weight:700;color:#1f2937}.kizyun-index__chapter-title{color:#6b7280;font-size:.875rem;margin-top:2px}.kizyun-index__chapter-arrow{color:#3b82f6;font-weight:700}.home-exam{background:radial-gradient(circle at top, #eef2ff 0%, #f8fafc 48%, #ffffff 100%);min-height:100vh}.home-exam__container{max-width:980px;margin:0 auto;padding:0 .25rem}@media(min-width: 1024px){.home-exam__container{padding:0 .5rem}}.home-exam__hero{padding:64px 0 20px}.home-exam__eyebrow{text-transform:uppercase;letter-spacing:.2em;font-size:.75rem;font-weight:700;color:#1d4ed8;margin-bottom:10px}.home-exam__title{font-size:2.2rem;font-weight:800;color:#0f172a;margin-bottom:12px}.home-exam__lead{font-size:1.05rem;color:#475569;max-width:720px}.home-exam__hero-meta{margin-top:28px;display:grid;grid-template-columns:repeat(auto-fit, minmax(240px, 1fr));gap:16px}.home-exam__main{padding:10px 0 72px}.home-exam__grid{display:grid;grid-template-columns:repeat(auto-fit, minmax(280px, 1fr));gap:20px}.home-exam__card{background:#fff;border-radius:18px;padding:22px;border:1px solid #e2e8f0;box-shadow:0 16px 28px rgba(15,23,42,.08)}.home-exam__card--contact{background:linear-gradient(135deg, rgba(15, 23, 42, 0.02), rgba(59, 130, 246, 0.08))}.home-exam__card--flow{background:linear-gradient(135deg, rgba(226, 232, 240, 0.35), rgba(255, 255, 255, 0.95));margin-top:20px}.home-exam__card-title{font-size:1.2rem;font-weight:800;color:#0b1f3a;margin-bottom:10px}.home-exam__columns{display:grid;grid-template-columns:repeat(auto-fit, minmax(200px, 1fr));gap:16px}.home-exam__label{font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:#1d4ed8;margin-bottom:8px}.home-exam__list{padding-left:18px;color:#334155;line-height:1.7}.home-exam__flow{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:16px}.home-exam__flow-step{display:grid;grid-template-columns:auto 1fr;gap:14px;align-items:flex-start;padding:14px 16px;border-radius:14px;background:#fff;border:1px solid #e2e8f0;box-shadow:0 12px 22px rgba(15,23,42,.08)}.home-exam__flow-index{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:12px;background:#1d4ed8;color:#fff;font-weight:800;font-size:.9rem}.home-exam__flow-title{font-size:1rem;font-weight:800;color:#0f172a;margin-bottom:4px}.home-exam__flow-text{color:#475569;line-height:1.6}.home-exam__flow-actions{margin-top:10px}.home-exam__flow-action{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;border-radius:999px;background:#1e3a8a;color:#fff;text-decoration:none;font-weight:700;font-size:.85rem;box-shadow:0 8px 16px rgba(30,58,138,.2);transition:transform .2s ease,box-shadow .2s ease,background .2s ease}.home-exam__flow-action:hover{background:#1d4ed8;transform:translateY(-1px);box-shadow:0 12px 20px rgba(30,58,138,.28)}.home-exam__overview{background:#fff;border-radius:20px;border:1px solid #e2e8f0;padding:32px;box-shadow:0 18px 30px rgba(15,23,42,.06)}.home-exam__overview-header{margin-bottom:24px}.home-exam__section-title{font-size:1.7rem;font-weight:800;color:#0f172a;margin-bottom:10px}.home-exam__overview-grid{display:grid;grid-template-columns:repeat(auto-fit, minmax(220px, 1fr));gap:16px;padding:18px 0;border-top:1px solid #e2e8f0;border-bottom:1px solid #e2e8f0}.home-exam__overview-item{padding:12px 0}.home-exam__overview-label{font-size:.8rem;color:#64748b;font-weight:700}.home-exam__overview-value{display:block;margin-top:8px;font-size:1.05rem;color:#0f172a}.home-exam__overview-sections{display:grid;gap:20px;margin-top:24px}.home-exam__overview-title{font-size:1rem;font-weight:800;color:#0f172a;margin-bottom:10px}.home-exam__text{color:#334155;line-height:1.7}.home-exam__link{color:#1d4ed8;font-weight:700;text-decoration:none}.home-exam__link:hover{text-decoration:underline}@media(max-width: 767px){.home-exam__hero{padding:44px 0 32px}.home-exam__title{font-size:1.7rem}.home-exam__lead{font-size:.95rem}.home-exam__overview{padding:24px}}.devise-container{min-height:100vh;background:linear-gradient(135deg, #f8fafc 0%, #e2e8f0 100%);display:flex;align-items:center;justify-content:center;padding:20px}.devise-form{background:#fff;border-radius:12px;box-shadow:0 20px 25px -5px rgba(0,0,0,.1),0 10px 10px -5px rgba(0,0,0,.04);padding:48px;width:100%;max-width:480px;border:1px solid #e2e8f0}@media(max-width: 767px){.devise-form{padding:32px 24px;margin:0 16px}}.devise-header{text-align:center;margin-bottom:40px}.devise-title{font-size:2rem;font-weight:700;color:#1e3a8a;margin-bottom:8px;font-family:"Noto Sans JP",sans-serif}.devise-subtitle{color:#64748b;font-size:1rem;font-weight:400}.devise-form-content .devise-field{margin-bottom:24px}.devise-form-content .devise-label{display:block;font-weight:600;color:#374151;margin-bottom:8px;font-size:.875rem}.devise-form-content .devise-help-text{font-size:.75rem;color:#9ca3af;font-weight:400;margin-left:8px}.devise-form-content .devise-input{width:100%;padding:12px 16px;border:2px solid #e5e7eb;border-radius:8px;font-size:1rem;transition:all .2s ease;background:#fff}.devise-form-content .devise-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px rgba(59,130,246,.1)}.devise-form-content .devise-input::placeholder{color:#9ca3af}.devise-form-content .devise-checkbox-field{display:flex;align-items:center;gap:12px;margin-bottom:32px}.devise-form-content .devise-checkbox{width:18px;height:18px;accent-color:#3b82f6;cursor:pointer}.devise-form-content .devise-checkbox-label{font-size:.875rem;color:#374151;cursor:pointer;margin:0}.devise-actions{margin-bottom:32px}.devise-btn{width:100%;padding:14px 24px;border-radius:8px;font-weight:700;font-size:1rem;border:none;cursor:pointer;transition:all .3s ease;text-align:center;text-decoration:none;display:inline-block}.devise-btn--primary{background:linear-gradient(135deg, #3b82f6, #1e3a8a);color:#fff}.devise-btn--primary:hover{background:linear-gradient(135deg, #2563eb, #1e40af);transform:translateY(-1px);box-shadow:0 10px 25px rgba(59,130,246,.3)}.devise-btn--primary:active{transform:translateY(0)}.devise-links{text-align:center;border-top:1px solid #e5e7eb;padding-top:24px;display:flex;flex-direction:column;gap:12px}.devise-link{color:#3b82f6;text-decoration:none;font-size:.875rem;font-weight:500;transition:color .2s ease}.devise-link:hover{color:#1e40af;text-decoration:underline}.devise-link--back{color:#6b7280;margin-top:8px}.devise-link--back:hover{color:#374151}#error_explanation{background:#fef2f2;border:1px solid #fecaca;border-radius:8px;padding:16px;margin-bottom:24px}#error_explanation h2{color:#dc2626;font-size:1rem;font-weight:600;margin-bottom:8px}#error_explanation ul{list-style:none;padding:0;margin:0}#error_explanation ul li{color:#dc2626;font-size:.875rem;margin-bottom:4px;padding-left:20px;position:relative}#error_explanation ul li::before{content:"•";position:absolute;left:0;color:#dc2626;font-weight:bold}#error_explanation ul li:last-child{margin-bottom:0}.alert{padding:12px 16px;border-radius:8px;margin-bottom:24px;font-size:.875rem;font-weight:500}.alert.alert-notice{background:#ecfdf5;color:#065f46;border:1px solid #a7f3d0}.alert.alert-alert{background:#fef2f2;color:#dc2626;border:1px solid #fecaca}.mypage{min-height:100vh;background:linear-gradient(180deg, #eff6ff 0%, #f8fafc 55%, #ffffff 100%)}.mypage__header{background:#f8fafc;border-bottom:1px solid #e2e8f0;box-shadow:0 12px 24px rgba(15,23,42,.08);padding:30px 0;position:relative;overflow:hidden}.mypage__header::before{content:"";position:absolute;top:-36px;right:-120px;width:260px;height:170px;background:linear-gradient(135deg, rgba(59, 130, 246, 0.2), rgba(14, 165, 233, 0.04));transform:skewX(-12deg);border-radius:28px;z-index:0}.mypage__header::after{content:"";position:absolute;bottom:-70px;left:-80px;width:200px;height:200px;border-radius:999px;background:radial-gradient(circle at 30% 30%, rgba(14, 165, 233, 0.16), rgba(59, 130, 246, 0.02) 65%);z-index:0}.mypage__header-inner{max-width:980px;margin:0 auto;padding:0 .25rem}@media(min-width: 1024px){.mypage__header-inner{padding:0 .5rem}}.mypage__header-inner{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;position:relative;z-index:1}@media(max-width: 767px){.mypage__header-inner{flex-direction:column;align-items:flex-start}}.mypage__eyebrow{font-size:.85rem;letter-spacing:.18em;text-transform:uppercase;color:#64748b;margin-bottom:6px;font-weight:700}.mypage__title{font-size:2rem;font-weight:800;color:#0b1f3a;margin-bottom:6px}.mypage__subtitle{color:#475569;font-size:1.05rem}.mypage__ghost-link{border:1px solid #c7d2fe;background:#fff;color:#1e40af;padding:10px 16px;border-radius:999px;text-decoration:none;font-weight:700;font-size:.95rem;transition:all .2s ease}.mypage__ghost-link:hover{background:#eff6ff;border-color:#93c5fd}.mypage__content{max-width:980px;margin:0 auto;padding:0 .25rem}@media(min-width: 1024px){.mypage__content{padding:0 .5rem}}.mypage__content{padding:30px 0 60px}.mypage__layout{display:grid;grid-template-columns:220px minmax(0, 1fr);gap:24px;align-items:start}@media(max-width: 767px){.mypage__layout{grid-template-columns:1fr}}.mypage__sidebar{position:relative}.mypage__nav{background:#fff;border:1px solid #e2e8f0;border-radius:16px;box-shadow:0 16px 24px rgba(30,64,175,.08);padding:16px;display:flex;flex-direction:column;gap:12px}@media(max-width: 767px){.mypage__nav{flex-direction:row;gap:10px;padding:12px}}.mypage__nav-link{padding:10px 12px;border-radius:10px;text-decoration:none;font-weight:700;color:#1e293b;background:#f8fafc;border:1px solid rgba(0,0,0,0);transition:all .2s ease;text-align:center}.mypage__nav-link:hover{background:#eff6ff;border-color:#c7d2fe;color:#1e40af}.mypage__nav-link.is-active{background:#1e40af;color:#fff;border-color:#1e40af;box-shadow:0 10px 18px rgba(30,64,175,.3)}.mypage__card{background:#fff;border:1px solid #e2e8f0;border-radius:16px;box-shadow:0 16px 30px rgba(30,64,175,.08);padding:28px 32px}@media(max-width: 767px){.mypage__card{padding:24px 20px}}.mypage__card-header{margin-bottom:24px}.mypage__card-title{font-size:1.4rem;font-weight:800;color:#1e40af;margin-bottom:8px}.mypage__card-lead{color:#64748b}.mypage__form{display:flex;flex-direction:column;gap:20px}.mypage__flash{margin-bottom:18px;padding:12px 16px;border-radius:10px;background:#ecfdf3;border:1px solid #86efac;color:#166534;font-weight:700}.mypage__section{padding-top:4px;display:flex;flex-direction:column;gap:12px}.mypage__section-title{font-size:1.1rem;font-weight:800;color:#0f172a}.mypage__section-lead{color:#64748b;font-size:.95rem}.mypage__field{display:flex;flex-direction:column;gap:6px}.mypage__label{font-size:.9rem;font-weight:700;color:#1f2937}.mypage__input{border:1px solid #cbd5f5;border-radius:10px;padding:12px 14px;font-size:1rem;color:#0f172a;background:#f8fafc;transition:border-color .2s ease,box-shadow .2s ease}.mypage__input:focus{outline:none;border-color:#1e40af;box-shadow:0 0 0 3px rgba(30,64,175,.15);background:#fff}.mypage__textarea{border:1px solid #cbd5f5;border-radius:10px;padding:12px 14px;font-size:1rem;color:#0f172a;background:#f8fafc;resize:vertical;min-height:120px;transition:border-color .2s ease,box-shadow .2s ease}.mypage__textarea:focus{outline:none;border-color:#1e40af;box-shadow:0 0 0 3px rgba(30,64,175,.15);background:#fff}.mypage__hint{font-size:.85rem;color:#64748b}.mypage__notice{padding:10px 14px;border-radius:10px;background:#eff6ff;border:1px solid #bfdbfe;color:#1e3a8a;font-size:.9rem}.mypage__actions{display:flex;gap:12px;flex-wrap:wrap}.mypage__primary-button{background:#1e40af;color:#fff;border:none;padding:12px 20px;border-radius:10px;font-weight:700;cursor:pointer;transition:all .2s ease}.mypage__primary-button:hover{background:#1d4ed8;transform:translateY(-1px)}.mypage__secondary-button{background:#eff6ff;color:#1e40af;border:1px solid #bfdbfe;padding:12px 20px;border-radius:10px;font-weight:700;text-decoration:none;transition:all .2s ease}.mypage__secondary-button:hover{background:#dbeafe;color:#1e3a8a}.mypage__stack{display:flex;flex-direction:column;gap:20px}.mypage__card--plan{background:linear-gradient(140deg, #ffffff 0%, #eff6ff 100%)}.mypage__plan-current{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:18px}@media(max-width: 767px){.mypage__plan-current{flex-direction:column;align-items:flex-start}}.mypage__plan-chip{background:#1e40af;color:#fff;font-weight:700;padding:8px 14px;border-radius:999px}.mypage__plan-note{color:#475569;font-weight:600;margin:0}.mypage__plan-usage{display:grid;grid-template-columns:repeat(2, minmax(0, 1fr));gap:16px;margin-bottom:20px}@media(max-width: 767px){.mypage__plan-usage{grid-template-columns:1fr}}.mypage__plan-usage-item{background:#fff;border:1px solid #dbeafe;border-radius:14px;padding:16px}.mypage__plan-usage-label{font-size:.85rem;color:#64748b;margin:0 0 6px 0;font-weight:700}.mypage__plan-usage-value{font-size:1.2rem;font-weight:800;color:#0f172a;margin:0 0 6px 0}.mypage__plan-usage-meta{color:#64748b;margin:0}.mypage__plan-actions{display:flex;gap:12px;flex-wrap:wrap}.learning-history{min-height:100vh;background:radial-gradient(circle at top, #eef2ff 0%, #f8fafc 50%, #ffffff 100%)}.learning-history__hero{background:#f8fafc;color:#0f172a;padding:44px 0;border-bottom:1px solid #e2e8f0;position:relative;overflow:hidden}.learning-history__hero::before{content:"";position:absolute;top:-40px;right:-120px;width:280px;height:180px;background:linear-gradient(135deg, rgba(59, 130, 246, 0.22), rgba(14, 165, 233, 0.04));transform:skewX(-12deg);border-radius:28px}.learning-history__hero::after{content:"";position:absolute;bottom:-60px;left:-80px;width:200px;height:200px;border-radius:999px;background:radial-gradient(circle at 30% 30%, rgba(14, 165, 233, 0.18), rgba(59, 130, 246, 0.02) 65%)}.learning-history__hero-inner{max-width:980px;margin:0 auto;padding:0 .25rem}@media(min-width: 1024px){.learning-history__hero-inner{padding:0 .5rem}}.learning-history__hero-inner{display:flex;align-items:center;justify-content:space-between;gap:24px}@media(max-width: 767px){.learning-history__hero-inner{flex-direction:column;align-items:flex-start}}.learning-history__eyebrow{text-transform:uppercase;letter-spacing:.18em;font-size:.75rem;font-weight:700;color:#2563eb;margin-bottom:8px}.learning-history__title{font-size:2.3rem;font-weight:800;margin-bottom:6px;color:#0b1f3a}.learning-history__subtitle{font-size:1rem;color:#64748b}.learning-history__hero-chip{background:#e0f2fe;border:1px solid rgba(14,116,144,.2);padding:10px 18px;border-radius:999px;font-weight:700;font-size:.9rem;color:#0f172a;box-shadow:0 8px 16px rgba(15,23,42,.06)}.learning-history__content{max-width:980px;margin:0 auto;padding:0 .25rem}@media(min-width: 1024px){.learning-history__content{padding:0 .5rem}}.learning-history__content{padding:36px 0 60px;display:flex;flex-direction:column;gap:40px}.learning-history__section-title{font-size:1.5rem;font-weight:800;color:#0b1f3a;margin-bottom:6px}.learning-history__section-subtitle{color:#64748b;max-width:520px}.learning-history__section-head{display:flex;align-items:flex-start;justify-content:space-between;gap:20px}@media(max-width: 767px){.learning-history__section-head{flex-direction:column;align-items:flex-start}}.learning-history__summary-grid{display:grid;grid-template-columns:repeat(auto-fit, minmax(180px, 1fr));gap:16px;margin-top:20px}.learning-history__summary-link{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;border-radius:999px;border:1px solid #dbeafe;background:#eff6ff;color:#1d4ed8;font-weight:700;font-size:.85rem;text-decoration:none;white-space:nowrap}.learning-history__summary-card{background:#fff;border-radius:16px;padding:18px 20px;border:1px solid #e2e8f0;box-shadow:0 12px 20px rgba(15,23,42,.08)}.learning-history__summary-label{font-size:.85rem;color:#64748b;font-weight:700;margin-bottom:8px}.learning-history__summary-value{font-size:1.8rem;font-weight:800;color:#1e40af;margin-bottom:4px}.learning-history__summary-unit{font-size:.85rem;color:#475569;margin-left:4px}.learning-history__summary-note{font-size:.85rem;color:#64748b}.learning-history__drill-trend{background:#fff;border-radius:20px;padding:24px;border:1px solid #e2e8f0;box-shadow:0 18px 32px rgba(15,23,42,.12)}.learning-history__toggle{display:inline-flex;gap:8px;padding:6px;background:#f1f5f9;border-radius:999px;border:1px solid #e2e8f0;margin:0}.learning-history__toggle-btn{appearance:none;border:none;padding:8px 16px;border-radius:999px;font-weight:700;font-size:.85rem;color:#64748b;background:rgba(0,0,0,0);cursor:pointer;transition:background .2s ease,color .2s ease,box-shadow .2s ease}.learning-history__toggle-btn.is-active{background:#1d4ed8;color:#fff;box-shadow:0 10px 20px rgba(29,78,216,.2)}.learning-history__bar-empty{margin-top:16px;background:#f8fafc;border:1px dashed #e2e8f0;border-radius:16px;padding:18px;text-align:center;color:#94a3b8;font-weight:700}.learning-history__drill-grid{display:grid;grid-template-columns:repeat(auto-fit, minmax(280px, 1fr));gap:18px;margin-top:20px}.learning-history__drill-card{background:#f8fafc;border-radius:16px;border:1px solid #e2e8f0;padding:16px;box-shadow:inset 0 1px 8px rgba(15,23,42,.05)}.learning-history__drill-header{display:flex;align-items:baseline;justify-content:space-between;gap:12px;margin-bottom:12px}.learning-history__drill-header h3{font-size:1rem;font-weight:800;color:#0f172a}.learning-history__drill-header span{font-size:.8rem;font-weight:700;color:#64748b}.learning-history__drill-chart{background:#fff;border-radius:14px;border:none;padding:20px;min-height:420px;box-shadow:inset 0 0 0 1px rgba(148,163,184,.22)}.learning-history__drill-chart canvas{width:100%;height:360px}.learning-history__map{background:#fff;border-radius:20px;padding:28px;border:1px solid #e2e8f0;box-shadow:0 20px 36px rgba(15,23,42,.12);display:flex;flex-direction:column;gap:18px}.learning-history__map--accordion{padding:0;overflow:hidden;transition:box-shadow .2s ease,transform .2s ease,border-color .2s ease;border:1px solid #d9e2ef}.learning-history__map-summary{list-style:none;cursor:pointer;padding:28px;background:#fff;transition:background .2s ease,transform .2s ease;border-radius:20px}.learning-history__map-summary:focus-visible{outline:2px solid #93c5fd;outline-offset:2px}.learning-history__map-summary::-webkit-details-marker{display:none}.learning-history__map-summary:hover{background:#fff}.learning-history__map--accordion:hover{box-shadow:0 16px 28px rgba(15,23,42,.12);transform:translateY(-2px);border-color:#c7d2fe}.learning-history__map-body{padding:0 28px 28px}.learning-history__map--accordion .learning-history__map-header{border-bottom:none;padding-bottom:0}.learning-history__map--accordion[open] .learning-history__map-header{border-bottom:1px solid #e2e8f0;padding-bottom:12px}.learning-history__map-header{display:flex;align-items:center;justify-content:space-between;gap:20px;padding-bottom:12px;border-bottom:1px solid #e2e8f0;position:relative}@media(max-width: 767px){.learning-history__map-header{flex-direction:column;align-items:flex-start}}.learning-history__map-actions{display:flex;align-items:center;gap:16px}@media(max-width: 767px){.learning-history__map-actions{width:100%;justify-content:space-between}}.learning-history__map-title{display:flex;flex-direction:column;gap:6px}.learning-history__map-cta{display:inline-flex;align-items:center;gap:8px;margin-top:6px;padding:6px 12px;border-radius:999px;font-size:.75rem;font-weight:700;color:#1e40af;background:#eff6ff;border:1px solid #bfdbfe;width:fit-content;transition:background .2s ease,color .2s ease,border-color .2s ease}.learning-history__map-cta-icon{width:10px;height:10px;border-right:2px solid currentColor;border-bottom:2px solid currentColor;transform:rotate(45deg);transition:transform .2s ease}.learning-history__map--accordion:hover .learning-history__map-cta{background:#dbeafe;border-color:#93c5fd;color:#1d4ed8}.learning-history__map--accordion[open] .learning-history__map-cta-icon{transform:rotate(-135deg)}.learning-history__map-metric{text-align:right;min-width:160px}@media(max-width: 767px){.learning-history__map-metric{text-align:left}}.learning-history__map-rate{font-size:2rem;font-weight:800;color:#1d4ed8}.learning-history__map-count{color:#64748b;font-weight:700}.learning-history__meter{background:#e2e8f0;border-radius:6px;height:24px;margin-bottom:20px;overflow:hidden;border:1px solid rgba(15,23,42,.18);box-shadow:inset 0 1px 4px rgba(15,23,42,.16);position:relative}.learning-history__meter::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg, rgba(255, 255, 255, 0.35), rgba(255, 255, 255, 0) 18%, rgba(15, 23, 42, 0) 70%, rgba(15, 23, 42, 0.12)),linear-gradient(90deg, rgba(168, 85, 247, 0.32), rgba(129, 140, 248, 0.28) 28%, rgba(96, 165, 250, 0.3) 50%, rgba(34, 211, 238, 0.28) 70%, rgba(37, 99, 235, 0.35));mix-blend-mode:screen;pointer-events:none}.learning-history__meter-strip{height:100%;display:flex;gap:0;padding:0}.learning-history__meter-segment{height:100%;flex:1;border-radius:0;background:#e2e8f0;box-shadow:inset 0 0 6px rgba(15,23,42,.08);filter:blur(0.35px)}.learning-history__meter-segment:first-child{border-top-left-radius:12px;border-bottom-left-radius:12px}.learning-history__meter-segment:last-child{border-top-right-radius:12px;border-bottom-right-radius:12px}.learning-history__meter-segment--level-0{background:#fff}.learning-history__meter-segment--level-1{background:#7dd3fc}.learning-history__meter-segment--level-2{background:#60a5fa}.learning-history__meter-segment--level-3{background:#1d4ed8}.learning-history__legend{display:flex;flex-wrap:wrap;gap:12px;font-size:.8rem;font-weight:700;color:#475569;margin-top:-6px}.learning-history__legend-item{display:inline-flex;align-items:center;gap:6px}.learning-history__legend-chip{width:16px;height:16px;border-radius:4px;background:#e2e8f0}.learning-history__legend-chip.is-level-0{background:#fff;border:1px solid #e2e8f0}.learning-history__legend-chip.is-level-1{background:#7dd3fc}.learning-history__legend-chip.is-level-2{background:#60a5fa}.learning-history__legend-chip.is-level-3{background:#1d4ed8}.learning-history__grid-wrap{background:#f8fafc;border-radius:16px;padding:20px;max-height:420px;overflow:auto;border:1px solid #e2e8f0;box-shadow:inset 0 1px 6px rgba(15,23,42,.06);position:relative;z-index:1}.learning-history__grid{display:grid;grid-template-columns:repeat(auto-fill, minmax(14px, 1fr));gap:6px;overflow:visible}.learning-history__cell{width:100%;aspect-ratio:1;border-radius:4px;background:#e2e8f0;transition:transform .15s ease,box-shadow .15s ease;position:relative;cursor:pointer}.learning-history__cell:hover{transform:scale(1.2);box-shadow:0 4px 10px rgba(15,23,42,.2);z-index:3}.learning-history__tooltip{position:fixed;left:0;top:0;transform:translate(-50%, -100%);background:#0f172a;color:#fff;padding:6px 10px;border-radius:8px;font-size:.75rem;white-space:nowrap;box-shadow:0 10px 20px rgba(15,23,42,.25);pointer-events:none;opacity:0;transition:opacity .12s ease;z-index:9999}.learning-history__tooltip.is-visible{opacity:1}.learning-history__cell--level-0{background:#fff;border:1px solid #e2e8f0}.learning-history__cell--level-1{background:#7dd3fc}.learning-history__cell--level-2{background:#60a5fa}.learning-history__cell--level-3{background:#1d4ed8}.learning-history__hint{margin-top:12px;font-size:.85rem;color:#64748b;text-align:right}.learning-history__hero{animation:learning-history-panel-in .45s ease}.learning-history__hero-text,.learning-history__hero-chip,.learning-history__section-head,.learning-history__summary-card,.learning-history__drill-trend,.learning-history__drill-card,.learning-history__map{animation:learning-history-rise .5s ease both}.learning-history__hero-text{animation-delay:.05s}.learning-history__hero-chip{animation-delay:.1s}.learning-history__section-head{animation-delay:.12s}.learning-history__summary-card{animation-delay:.06s}.learning-history__summary-card:nth-child(2){animation-delay:.1s}.learning-history__summary-card:nth-child(3){animation-delay:.14s}.learning-history__summary-card:nth-child(4){animation-delay:.18s}.learning-history__summary-card:nth-child(5){animation-delay:.22s}.learning-history__drill-trend{animation-delay:.14s}.learning-history__drill-card{animation-delay:.1s}.learning-history__drill-card:nth-child(2){animation-delay:.14s}.learning-history__drill-card:nth-child(3){animation-delay:.18s}.learning-history__map{animation-delay:.16s}.learning-history__map+.learning-history__map{animation-delay:.2s}@keyframes learning-history-panel-in{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes learning-history-rise{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}@media(prefers-reduced-motion: reduce){.learning-history__hero,.learning-history__hero-text,.learning-history__hero-chip,.learning-history__section-head,.learning-history__summary-card,.learning-history__drill-trend,.learning-history__drill-card,.learning-history__map{animation:none}}.weekly-report{min-height:100vh;background:radial-gradient(circle at top, #eef2ff 0%, #f8fafc 50%, #ffffff 100%)}.weekly-report__hero{background:#f8fafc;color:#0f172a;padding:44px 0;border-bottom:1px solid #e2e8f0;position:relative;overflow:hidden}.weekly-report__hero::before{content:"";position:absolute;top:-40px;right:-120px;width:280px;height:180px;background:linear-gradient(135deg, rgba(59, 130, 246, 0.22), rgba(14, 165, 233, 0.04));transform:skewX(-12deg);border-radius:28px}.weekly-report__hero::after{content:"";position:absolute;bottom:-60px;left:-80px;width:200px;height:200px;border-radius:999px;background:radial-gradient(circle at 30% 30%, rgba(14, 165, 233, 0.18), rgba(59, 130, 246, 0.02) 65%)}.weekly-report__hero-inner{max-width:980px;margin:0 auto;padding:0 .25rem}@media(min-width: 1024px){.weekly-report__hero-inner{padding:0 .5rem}}.weekly-report__hero-inner{display:flex;align-items:center;justify-content:space-between;gap:24px}@media(max-width: 767px){.weekly-report__hero-inner{flex-direction:column;align-items:flex-start}}.weekly-report__eyebrow{text-transform:uppercase;letter-spacing:.18em;font-size:.75rem;font-weight:700;color:#2563eb;margin-bottom:8px}.weekly-report__title{font-size:2.3rem;font-weight:800;margin-bottom:6px;color:#0b1f3a}.weekly-report__subtitle{font-size:1rem;color:#64748b}.weekly-report__hero-chip{background:#e0f2fe;border:1px solid rgba(14,116,144,.2);padding:10px 18px;border-radius:999px;font-weight:700;font-size:.9rem;color:#0f172a;box-shadow:0 8px 16px rgba(15,23,42,.06)}.weekly-report__content{max-width:980px;margin:0 auto;padding:0 .25rem}@media(min-width: 1024px){.weekly-report__content{padding:0 .5rem}}.weekly-report__content{padding:36px 0 60px;display:flex;flex-direction:column;gap:32px}.weekly-report__section-title{font-size:1.5rem;font-weight:800;color:#0b1f3a;margin-bottom:6px}.weekly-report__summary-grid{display:grid;grid-template-columns:repeat(auto-fit, minmax(180px, 1fr));gap:16px;margin-top:20px}.weekly-report__summary-card{background:#fff;border-radius:16px;padding:18px 20px;border:1px solid #e2e8f0;box-shadow:0 12px 20px rgba(15,23,42,.08)}.weekly-report__summary-label{font-size:.85rem;color:#64748b;font-weight:700;margin-bottom:8px}.weekly-report__summary-value{font-size:1.8rem;font-weight:800;color:#1e40af;margin-bottom:4px}.weekly-report__summary-unit{font-size:.85rem;color:#475569;margin-left:4px}.weekly-report__summary-note{font-size:.85rem;color:#64748b}.learning-goals{min-height:100vh;background:radial-gradient(circle at top, #eef2ff 0%, #f8fafc 50%, #ffffff 100%)}.learning-goals__hero{background:#f8fafc;color:#0f172a;padding:44px 0;border-bottom:1px solid #e2e8f0;position:relative;overflow:hidden}.learning-goals__hero::before{content:"";position:absolute;top:-40px;right:-120px;width:280px;height:180px;background:linear-gradient(135deg, rgba(59, 130, 246, 0.22), rgba(14, 165, 233, 0.04));transform:skewX(-12deg);border-radius:28px}.learning-goals__hero::after{content:"";position:absolute;bottom:-60px;left:-80px;width:200px;height:200px;border-radius:999px;background:radial-gradient(circle at 30% 30%, rgba(14, 165, 233, 0.18), rgba(59, 130, 246, 0.02) 65%)}.learning-goals__hero-inner{max-width:980px;margin:0 auto;padding:0 .25rem}@media(min-width: 1024px){.learning-goals__hero-inner{padding:0 .5rem}}.learning-goals__hero-inner{display:flex;align-items:center;justify-content:space-between;gap:24px}@media(max-width: 767px){.learning-goals__hero-inner{flex-direction:column;align-items:flex-start}}.learning-goals__eyebrow{text-transform:uppercase;letter-spacing:.18em;font-size:.75rem;font-weight:700;color:#2563eb;margin-bottom:8px}.learning-goals__title{font-size:2.3rem;font-weight:800;margin-bottom:6px;color:#0b1f3a}.learning-goals__subtitle{font-size:1rem;color:#64748b}.learning-goals__hero-chip{background:#e0f2fe;border:1px solid rgba(14,116,144,.2);padding:10px 18px;border-radius:999px;font-weight:700;font-size:.9rem;color:#0f172a;box-shadow:0 8px 16px rgba(15,23,42,.06)}.learning-goals__content{max-width:980px;margin:0 auto;padding:0 .25rem}@media(min-width: 1024px){.learning-goals__content{padding:0 .5rem}}.learning-goals__content{padding:36px 0 60px;display:flex;flex-direction:column;gap:32px}.learning-goals__flash{background:#ecfeff;border:1px solid #bae6fd;border-radius:12px;padding:12px 16px;font-weight:700;color:#0f172a}.learning-goals__section-head{display:flex;align-items:flex-start;justify-content:space-between;gap:20px}@media(max-width: 767px){.learning-goals__section-head{flex-direction:column;align-items:flex-start}}.learning-goals__section-title{font-size:1.5rem;font-weight:800;color:#0b1f3a;margin-bottom:6px}.learning-goals__section-subtitle{color:#64748b}.learning-goals__chip{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;border-radius:999px;border:1px solid #dbeafe;background:#eff6ff;color:#1d4ed8;font-weight:700;font-size:.85rem;white-space:nowrap}.learning-goals__grid{display:grid;grid-template-columns:repeat(auto-fit, minmax(220px, 1fr));gap:16px;margin-top:16px}.learning-goals__card{background:#fff;border-radius:16px;padding:18px 20px;border:1px solid #e2e8f0;box-shadow:0 12px 20px rgba(15,23,42,.08);display:flex;flex-direction:column;gap:10px}.learning-goals__label{font-size:.85rem;font-weight:700;color:#64748b}.learning-goals__value{font-size:1.5rem;font-weight:800;color:#1e293b}.learning-goals__unit{font-size:.85rem;color:#94a3b8;margin-left:6px}.learning-goals__bar{height:10px;background:#e2e8f0;border-radius:999px;overflow:hidden}.learning-goals__bar span{display:block;height:100%;background:linear-gradient(90deg, #1d4ed8, #60a5fa);border-radius:999px}.learning-goals__form{background:#fff;border-radius:20px;padding:24px;border:1px solid #e2e8f0;box-shadow:0 18px 32px rgba(15,23,42,.12);display:grid;gap:16px}.learning-goals__divider{height:1px;background:#e2e8f0;border:none;margin:8px 0}.learning-goals__field{display:flex;flex-direction:column;gap:8px}.learning-goals__input{border:1px solid #e2e8f0;border-radius:10px;padding:10px 12px;font-size:1rem}.learning-goals__actions{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.learning-goals__primary-button{padding:10px 18px;border-radius:10px;border:none;background:#1d4ed8;color:#fff;font-weight:700}.learning-goals__secondary-button{padding:10px 18px;border-radius:10px;border:1px solid #d1d5db;color:#374151;background:#fff;font-weight:700;text-decoration:none}.learning-goals__hero{animation:learning-goals-panel-in .45s ease}.learning-goals__hero-inner>div:first-child,.learning-goals__hero-chip,.learning-goals__flash,.learning-goals__section-head,.learning-goals__card,.learning-goals__form,.learning-goals__field,.learning-goals__actions{animation:learning-goals-rise .5s ease both}.learning-goals__hero-inner>div:first-child{animation-delay:.05s}.learning-goals__hero-chip{animation-delay:.1s}.learning-goals__flash{animation-delay:.12s}.learning-goals__section-head{animation-delay:.14s}.learning-goals__grid .learning-goals__card{animation-delay:.16s}.learning-goals__grid .learning-goals__card:nth-child(2){animation-delay:.2s}.learning-goals__grid .learning-goals__card:nth-child(3){animation-delay:.24s}.learning-goals__grid .learning-goals__card:nth-child(4){animation-delay:.28s}.learning-goals__grid .learning-goals__card:nth-child(5){animation-delay:.32s}.learning-goals__form{animation-delay:.18s}.learning-goals__field{animation-delay:.2s}.learning-goals__actions{animation-delay:.24s}@keyframes learning-goals-panel-in{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes learning-goals-rise{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}@media(prefers-reduced-motion: reduce){.learning-goals__hero,.learning-goals__hero-inner>div:first-child,.learning-goals__hero-chip,.learning-goals__flash,.learning-goals__section-head,.learning-goals__card,.learning-goals__form,.learning-goals__field,.learning-goals__actions{animation:none}}.kizyun-viewer{display:flex;flex-direction:column;gap:24px;padding-bottom:56px;max-width:none;margin:0;font-family:"Yu Mincho","Hiragino Mincho ProN","MS Mincho",serif;color:#111827}.kizyun-viewer__hero{background:#f8fafc;border-bottom:1px solid #e2e8f0;padding:24px 0;position:relative;overflow:hidden;box-shadow:0 12px 24px rgba(15,23,42,.08)}.kizyun-viewer__hero::before{content:"";position:absolute;top:-26px;right:-120px;width:240px;height:160px;background:linear-gradient(135deg, rgba(59, 130, 246, 0.2), rgba(14, 165, 233, 0.05));transform:skewX(-12deg);border-radius:28px;z-index:0}.kizyun-viewer__hero::after{content:"";position:absolute;bottom:-70px;left:-70px;width:200px;height:200px;border-radius:999px;background:radial-gradient(circle at 30% 30%, rgba(14, 165, 233, 0.16), rgba(59, 130, 246, 0.02) 65%);z-index:0}.kizyun-viewer__header{display:flex;flex-wrap:wrap;gap:16px 24px;align-items:flex-start;justify-content:space-between;max-width:980px;margin:0 auto;padding:0 .25rem}@media(min-width: 1024px){.kizyun-viewer__header{padding:0 .5rem}}.kizyun-viewer__header{position:relative;z-index:1}.kizyun-viewer__title{position:relative;z-index:1}.kizyun-viewer__title h1{font-size:1.5rem;margin:0 0 4px;letter-spacing:.02em;color:#0b1f3a}.kizyun-viewer__title p{margin:0;color:#64748b;font-size:.95rem}.kizyun-viewer__controls{display:flex;gap:18px;flex-wrap:wrap;position:relative;z-index:1}.kizyun-viewer__inner{max-width:980px;margin:0 auto;padding:0 .25rem}@media(min-width: 1024px){.kizyun-viewer__inner{padding:0 .5rem}}.kizyun-viewer__inner{padding-top:28px}.kizyun-viewer__control-group{display:flex;flex-direction:column;gap:8px}.kizyun-viewer__control-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.12em;font-weight:700;color:#64748b}.kizyun-viewer__pill-group{display:inline-flex;align-items:center;gap:8px;flex-wrap:wrap}.kizyun-viewer__pill{display:inline-flex;align-items:center;justify-content:center;padding:8px 14px;border-radius:999px;font-size:.85rem;font-weight:700;color:#1f2937;background:#f8fafc;border:1px solid #e2e8f0;text-decoration:none;transition:all .2s ease}.kizyun-viewer__pill:hover{transform:translateY(-1px);border-color:#94a3b8}.kizyun-viewer__pill.is-active{background:#1e40af;border-color:#1e40af;color:#fff;box-shadow:0 10px 18px rgba(30,64,175,.25)}.kizyun-viewer__select-wrap{position:relative}.kizyun-viewer__select-wrap select{min-width:220px;padding:8px 34px 8px 12px;border-radius:999px;border:1px solid #e2e8f0;background:#f8fafc;font-size:.9rem;font-weight:600;color:#1f2937;appearance:none}.kizyun-viewer__select-wrap::after{content:"";position:absolute;right:14px;top:50%;width:8px;height:8px;border-right:2px solid #64748b;border-bottom:2px solid #64748b;transform:translateY(-60%) rotate(45deg);pointer-events:none}.kizyun-viewer__layout{display:grid;grid-template-columns:220px minmax(0, 1fr);gap:24px;align-items:start}.kizyun-viewer__toc{position:sticky;top:24px;align-self:start;background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:16px;box-shadow:0 14px 22px rgba(15,23,42,.06)}.kizyun-viewer__toc-header{font-size:.85rem;font-weight:800;color:#0f172a;margin-bottom:12px}.kizyun-viewer__toc-list{display:flex;flex-direction:column;gap:8px}.kizyun-viewer__toc-link{font-size:.85rem;color:#334155;text-decoration:none;border-left:2px solid rgba(0,0,0,0);padding-left:10px;transition:color .2s ease,border-color .2s ease}.kizyun-viewer__toc-link:hover{color:#1e40af;border-color:#93c5fd}.kizyun-viewer__toc-link.is-active{color:#1e40af;border-color:#1e40af;font-weight:700}.kizyun-viewer__toc-link.is-sub{font-size:.8rem;color:#64748b;padding-left:18px}.kizyun-viewer__toc-empty{font-size:.8rem;color:#94a3b8}.kizyun-viewer__chapter{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:32px 36px;box-shadow:0 16px 28px rgba(15,23,42,.08)}.kizyun-viewer__chapter-header{display:flex;flex-wrap:wrap;gap:10px;align-items:baseline;border-bottom:2px solid #3b82f6;padding-bottom:12px;margin-bottom:22px}.kizyun-viewer__chapter-number{font-weight:700;color:#1e40af;font-size:.85rem;padding:4px 10px;background:rgba(59,130,246,.12);border-radius:999px;border:1px solid rgba(59,130,246,.2)}.kizyun-viewer__chapter-title{margin:0;font-size:1.4rem;color:#1e3a8a}.kizyun-viewer__content{line-height:2;font-size:1rem;letter-spacing:.01em}.kizyun-viewer__content p{margin:0 0 1.2rem;text-indent:1em}.kizyun-viewer__content h2{font-size:1.1rem;margin:1.4rem 0 .6rem;color:#111827;font-weight:700}.kizyun-viewer__content h3{font-size:1rem;margin:1rem 0 .5rem;color:#111827;font-weight:600}.kizyun-viewer__content .kizyun-viewer__section-body{margin-left:2.4rem;margin-top:.2rem}.kizyun-viewer__content .kizyun-viewer__section-body ul{padding-left:.8rem}.kizyun-viewer__content ul{list-style:none;padding-left:1.2rem;margin:.6rem 0 1.2rem}.kizyun-viewer__content li{margin-bottom:.6rem;text-indent:0}.kizyun-viewer__content ul ul{padding-left:2rem;margin-top:.5rem}.kizyun-viewer__content ul ul ul{padding-left:2.4rem;margin-top:.4rem}.kizyun-viewer__content .math-display{text-align:center;margin:1rem 0}.kizyun-viewer__content .ryuiziko-note{margin:1.4rem 0;padding:1rem 1.2rem;border:1px solid #f4c98a;border-left:6px solid #f59e0b;background:#fff7ed;border-radius:6px;text-indent:0;box-shadow:0 6px 16px rgba(245,158,11,.08)}.kizyun-viewer__content .ryuiziko-note__title{font-weight:700;color:#92400e;font-size:.95rem;margin-bottom:.6rem;letter-spacing:.04em}.kizyun-viewer__content .ryuiziko-note p{text-indent:0;margin-bottom:.8rem}.kizyun-viewer__content .ryuiziko-note ul{margin:.4rem 0 .8rem;padding-left:1.2rem}.kizyun-viewer__mode-note{margin-top:18px;padding:10px 14px;border-radius:6px;background:#f1f5f9;color:#475569;font-size:.88rem;border:1px solid #e2e8f0}.kizyun-viewer__empty{text-align:center;color:#94a3b8}.kizyun-viewer__hero{animation:kantei-panel-in .45s ease}.kizyun-viewer__title,.kizyun-viewer__controls,.kizyun-viewer__control-group,.kizyun-viewer__toc,.kizyun-viewer__chapter,.kizyun-viewer__chapter-header,.kizyun-viewer__content,.kizyun-viewer__mode-note{animation:kantei-rise .5s ease both}.kizyun-viewer__title{animation-delay:.05s}.kizyun-viewer__controls{animation-delay:.1s}.kizyun-viewer__control-group:nth-child(2){animation-delay:.14s}.kizyun-viewer__toc{animation-delay:.12s}.kizyun-viewer__chapter{animation-delay:.18s}.kizyun-viewer__chapter-header{animation-delay:.22s}.kizyun-viewer__content{animation-delay:.26s}.kizyun-viewer__mode-note{animation-delay:.3s}@keyframes kantei-panel-in{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes kantei-rise{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}@media(prefers-reduced-motion: reduce){.kizyun-viewer__hero,.kizyun-viewer__title,.kizyun-viewer__controls,.kizyun-viewer__control-group,.kizyun-viewer__toc,.kizyun-viewer__chapter,.kizyun-viewer__chapter-header,.kizyun-viewer__content,.kizyun-viewer__mode-note{animation:none}}@media(max-width: 720px){.kizyun-viewer{padding-bottom:40px}.kizyun-viewer__hero{padding:20px 0}.kizyun-viewer__inner{padding-top:20px}.kizyun-viewer__layout{grid-template-columns:1fr}.kizyun-viewer__toc{position:static}.kizyun-viewer__select-wrap select{min-width:160px}.kizyun-viewer__chapter{padding:20px}}.plan-page{min-height:100vh;background:linear-gradient(180deg, #f8fafc 0%, #ffffff 55%, #eff6ff 100%)}.plan-hero{padding:40px 0 20px;background:radial-gradient(1200px 420px at 10% -20%, rgba(14, 165, 233, 0.2), rgba(255, 255, 255, 0) 60%);border-bottom:1px solid rgba(148,163,184,.2)}.plan-hero__inner{max-width:980px;margin:0 auto;padding:0 .25rem}@media(min-width: 1024px){.plan-hero__inner{padding:0 .5rem}}.plan-hero__inner{display:flex;align-items:center;justify-content:space-between;gap:24px}@media(max-width: 767px){.plan-hero__inner{flex-direction:column;align-items:flex-start}}.plan-hero__eyebrow{text-transform:uppercase;letter-spacing:.18em;font-size:.75rem;font-weight:700;color:#1d4ed8;margin-bottom:6px}.plan-hero__title{font-size:2.2rem;font-weight:800;color:#0b1f3a;margin:0 0 8px 0}.plan-hero__subtitle{color:#475569;margin:0}.plan-hero__panel{background:#fff;border:1px solid #dbeafe;border-radius:16px;padding:16px 18px;box-shadow:0 12px 22px rgba(30,64,175,.12);max-width:280px}.plan-hero__panel-title{font-weight:800;margin:0 0 6px 0;color:#1e3a8a}.plan-hero__panel-text{margin:0;color:#64748b;font-size:.92rem}.plan-main{max-width:980px;margin:0 auto;padding:0 .25rem}@media(min-width: 1024px){.plan-main{padding:0 .5rem}}.plan-main{padding:36px 0 60px}.plan-grid{display:grid;grid-template-columns:repeat(3, minmax(0, 1fr));gap:20px}@media(max-width: 767px){.plan-grid{grid-template-columns:1fr}}.plan-grid--compact{gap:16px}.plan-card{background:#fff;border:1px solid #e2e8f0;border-radius:18px;padding:22px 20px;box-shadow:0 16px 28px rgba(15,23,42,.08);display:flex;flex-direction:column;gap:16px;position:relative}.plan-card--accent{border-color:#93c5fd;box-shadow:0 18px 32px rgba(37,99,235,.2)}.plan-card--coach{border-color:#cbd5f5;background:linear-gradient(160deg, #ffffff 0%, #eff6ff 100%)}.plan-card--current{border-color:#1d4ed8;box-shadow:0 18px 32px rgba(29,78,216,.25)}.plan-card__label{text-transform:uppercase;letter-spacing:.16em;font-size:.72rem;font-weight:700;color:#64748b;margin:0 0 6px 0}.plan-card__title{font-size:1.35rem;font-weight:800;margin:0 0 6px 0;color:#0f172a}.plan-card__price{font-size:1.1rem;font-weight:700;color:#1d4ed8;margin:0}.plan-card__list{list-style:none;padding:0;margin:0;display:grid;gap:8px;color:#475569}.plan-card__cta{text-decoration:none;background:#1d4ed8;color:#fff;font-weight:700;text-align:center;padding:10px 14px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;transition:all .2s ease}.plan-card__cta:hover{background:#1e40af}.plan-card__cta--ghost{background:#fff;color:#1d4ed8;border:1px solid #c7d2fe}.plan-card__cta--muted{background:#e2e8f0;color:#475569}.error-page{padding:4rem 1.5rem;min-height:calc(100vh - 160px);display:grid;place-items:center;background:radial-gradient(circle at top, #f8fafc 0%, #e2e8f0 60%, #cbd5e1 100%)}.error-card{width:min(720px,100%);background:#fff;border:1px solid var(--border-light);border-radius:.5rem;box-shadow:0 20px 25px -5px rgba(0,0,0,.2);padding:3rem;display:grid;gap:1.5rem}.error-card__code{font-size:2.25rem;font-weight:700;color:var(--primary-red);letter-spacing:.08em}.error-card__title{font-size:1.75rem;font-weight:700;color:var(--text-primary)}.error-card__message{color:var(--text-secondary);line-height:1.75}.error-card__actions{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.5rem}.error-card__button{border:1px solid var(--border-default);border-radius:999px;padding:10px 18px;text-decoration:none;color:var(--text-primary);font-weight:500;transition:transform .15s ease,box-shadow .15s ease}.error-card__button:hover{transform:translateY(-1px);box-shadow:0 8px 16px rgba(15,23,42,.15)}.error-card__button--primary{background:linear-gradient(135deg, #1e40af 0%, #0b1f3a 100%);color:#fff;border-color:rgba(0,0,0,0)}@media(max-width: 640px){.error-card{padding:2rem}}.learnings-dashboard{min-height:100vh;--dash-ink: #0b1f3a;--dash-muted: #56657a;--dash-soft: #94a3b8;--dash-accent: #1d4ed8;--dash-accent-strong: #0f172a;--dash-accent-cool: #0ea5e9;--dash-surface: rgba(255, 255, 255, 0.92);--dash-surface-strong: #ffffff;--dash-border: rgba(15, 23, 42, 0.12);--dash-shadow: 0 18px 34px rgba(15, 23, 42, 0.08);background:radial-gradient(1200px 420px at 10% -10%, rgba(14, 165, 233, 0.18), rgba(255, 255, 255, 0) 60%),radial-gradient(900px 480px at 90% 0%, rgba(29, 78, 216, 0.14), rgba(255, 255, 255, 0) 65%),linear-gradient(180deg, #f1f5ff 0%, #f8fafc 55%, #ffffff 100%);color:var(--dash-ink);position:relative;overflow:hidden}.learnings-hero{background:linear-gradient(135deg, rgba(255, 255, 255, 0.94), rgba(239, 246, 255, 0.92));border-bottom:1px solid rgba(148,163,184,.25);padding:42px 0 26px;position:relative;overflow:hidden}.learnings-hero::before{content:"";position:absolute;top:-36px;right:-120px;width:340px;height:210px;background:linear-gradient(130deg, rgba(29, 78, 216, 0.18), rgba(14, 165, 233, 0.06));transform:skewX(-10deg);border-radius:32px}.learnings-hero::after{content:"";position:absolute;bottom:-110px;left:-70px;width:260px;height:260px;border-radius:999px;background:radial-gradient(circle at 30% 30%, rgba(14, 165, 233, 0.18), rgba(59, 130, 246, 0.02) 65%)}.learnings-hero__inner{max-width:980px;margin:0 auto;padding:0 .25rem}@media(min-width: 1024px){.learnings-hero__inner{padding:0 .5rem}}.learnings-hero__inner{display:flex;align-items:center;justify-content:space-between;gap:28px;position:relative;z-index:1}@media(max-width: 767px){.learnings-hero__inner{flex-direction:column;align-items:flex-start}}.learnings-hero__text{max-width:560px}.learnings-hero__eyebrow{text-transform:uppercase;letter-spacing:.18em;font-size:.75rem;font-weight:700;color:var(--dash-accent);margin-bottom:10px}.learnings-hero__title{font-size:2.2rem;font-weight:800;color:var(--dash-ink);margin:0 0 8px 0}.learnings-hero__subtitle{color:var(--dash-muted);font-size:1rem;margin:0 0 14px 0}.learnings-hero__actions{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.learnings-hero__cta{box-shadow:0 10px 20px rgba(30,64,175,.18)}.learnings-hero__ghost{border-color:#bfdbfe}.learnings-hero__panel{background:hsla(0,0%,100%,.92);border:1px solid rgba(148,163,184,.28);border-radius:20px;padding:18px 22px;min-width:240px;box-shadow:var(--dash-shadow);display:flex;flex-direction:column;gap:8px}@media(max-width: 767px){.learnings-hero__panel{width:100%}}.learnings-hero__panel-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.16em;color:var(--dash-soft);font-weight:700}.learnings-hero__panel-title{font-size:1.1rem;font-weight:800;color:var(--dash-accent-strong)}.learnings-hero__panel-text{color:var(--dash-muted);font-size:.92rem;margin:0}.learnings-hero__panel-cta{align-self:flex-start;padding:8px 14px;font-size:.95rem}.learnings-hero__panel-actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:6px}.learnings-hero__panel-cta--primary{background:var(--dash-accent);color:#fff;border-color:var(--dash-accent)}.learnings-hero__panel-cta--primary:hover{background:#1e40af;border-color:#1e40af}.dashboard-section{display:flex;flex-direction:column;gap:12px;padding:20px 0;border-top:1px solid rgba(148,163,184,.18);background:rgba(0,0,0,0);box-shadow:none;position:relative;overflow:hidden}.dashboard-section__header{display:flex;align-items:center;justify-content:space-between;gap:12px}.dashboard-section__title{font-size:1.1rem;font-weight:800;color:var(--dash-ink);margin:0}.usage-grid{display:grid;grid-template-columns:repeat(2, minmax(0, 1fr));gap:16px}@media(max-width: 767px){.usage-grid{grid-template-columns:1fr}}.usage-card{background:var(--dash-surface-strong);border:1px solid rgba(148,163,184,.25);border-radius:16px;padding:16px;box-shadow:0 12px 22px rgba(15,23,42,.08)}.usage-card__label{font-size:.85rem;font-weight:700;color:var(--dash-soft);margin-bottom:6px}.usage-card__value{font-size:1.2rem;font-weight:800;color:var(--dash-ink)}.usage-card__unit{font-size:.9rem;color:var(--dash-soft);margin-left:6px}.usage-card__meta{margin:6px 0 0;color:var(--dash-muted)}.usage-actions{display:flex;gap:12px;flex-wrap:wrap}.dashboard-section__meta{font-size:.85rem;font-weight:700;color:var(--dash-muted)}.dashboard-section--summary{border-top:none}.dashboard-section--summary,.dashboard-section--resume{padding:14px 0 18px;background:rgba(0,0,0,0);border-left:none;border-top:none;border-bottom:1px solid rgba(148,163,184,.18)}.summary-grid{display:grid;grid-template-columns:repeat(auto-fit, minmax(200px, 1fr));gap:14px}.summary-card{background:rgba(0,0,0,0);border-radius:0;padding:10px 0 10px 14px;border:none;box-shadow:none;display:flex;flex-direction:column;gap:6px;position:relative;overflow:hidden;border-left:1px solid rgba(148,163,184,.2)}.summary-card:first-child{border-left:none;padding-left:0}.summary-card--accent{background:rgba(0,0,0,0)}.summary-card__label{font-size:.85rem;font-weight:700;color:var(--dash-muted)}.summary-card__value{font-size:1.6rem;font-weight:800;color:var(--dash-ink);display:flex;align-items:baseline;gap:6px}.summary-card__unit{font-size:.95rem;font-weight:700;color:var(--dash-soft)}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fit, minmax(300px, 1fr));gap:28px}.dashboard-card{background:rgba(0,0,0,0);border:none;border-top:1px solid rgba(148,163,184,.28);border-radius:0;padding:18px 0 0;box-shadow:none;display:flex;flex-direction:column;gap:14px;position:relative;overflow:hidden}.dashboard-card::before{content:none}.dashboard-card--muted{background:rgba(0,0,0,0);border-top-style:dashed;color:var(--dash-muted)}.dashboard-card__header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.dashboard-card__eyebrow{font-size:.7rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--dash-soft)}.dashboard-card__title{font-size:1.2rem;font-weight:800;color:var(--dash-ink);margin:6px 0 0 0}.dashboard-card__badge{font-size:.75rem;font-weight:700;padding:6px 10px;border-radius:999px;background:rgba(29,78,216,.12);color:#1e3a8a;border:1px solid rgba(29,78,216,.2)}.dashboard-card__badge--accent{background:rgba(14,165,233,.16);color:#0e7490;border:1px solid rgba(14,165,233,.28)}.dashboard-card__body{display:flex;flex-direction:column;gap:12px}.dashboard-card__row{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;padding:10px 0;border-top:1px solid rgba(148,163,184,.18)}.dashboard-card__row:first-child{border-top:none;padding-top:0}.dashboard-card__name{font-weight:700;color:var(--dash-ink)}.dashboard-card__desc{color:var(--dash-muted);font-size:.92rem}.resume-list{display:flex;flex-direction:column;gap:12px;margin-top:0}.resume-item{display:grid;grid-template-columns:150px 1fr auto;align-items:center;gap:16px;padding:16px 0;border-radius:0;border:none;background:rgba(0,0,0,0);box-shadow:none;border-top:1px solid rgba(148,163,184,.2);transition:background .2s ease}.resume-item:first-child{border-top:none;padding-top:6px}.resume-item:hover{background:rgba(15,23,42,.02)}.resume-item:last-child{border-bottom:none}.resume-item__subject{font-weight:800;color:#1e3a8a;font-size:1.1rem}.resume-item__content{display:flex;flex-direction:column;gap:8px}.resume-item__detail{color:var(--dash-ink);font-size:1.12rem}.resume-item__progress{display:flex;align-items:center;gap:12px}.resume-item__progress-bar{flex:1;height:10px;background:#e2e8f0;border-radius:999px;overflow:hidden}.resume-item__progress-bar span{display:block;height:100%;background:linear-gradient(90deg, #1e40af, #60a5fa);border-radius:999px}.resume-item__progress-label{font-size:.92rem;color:var(--dash-muted);min-width:72px;text-align:right}.resume-item__action{color:#1e40af;font-weight:800;text-decoration:none;padding:10px 18px;border:1px solid rgba(29,78,216,.35);border-radius:999px;background:#1e40af;font-size:1.02rem;color:#fff;box-shadow:none}.resume-item__action:hover{background:#1d4ed8;border-color:rgba(147,197,253,.6);transform:translateY(-1px)}.resume-item.is-disabled{opacity:.6}.resume-item.is-disabled .resume-item__action{border-color:#e2e8f0;background:#f8fafc;color:#94a3b8}.dashboard-main{max-width:980px;margin:0 auto;padding:0 .25rem}@media(min-width: 1024px){.dashboard-main{padding:0 .5rem}}.dashboard-main{padding:36px 0 80px}@media(max-width: 767px){.dashboard-main{padding:40px 0}}.dashboard-split{display:grid;grid-template-columns:minmax(220px, 280px) minmax(0, 1fr);gap:24px;align-items:start}@media(max-width: 767px){.dashboard-split{grid-template-columns:1fr;gap:20px}}.dashboard-menu{position:sticky;top:120px;max-height:calc(100vh - 140px);overflow-y:auto;background:hsla(0,0%,100%,.92);border:1px solid rgba(148,163,184,.25);border-radius:18px;padding:16px;box-shadow:0 16px 28px rgba(15,23,42,.08)}@media(max-width: 767px){.dashboard-menu{position:sticky;top:88px;max-height:calc(100vh - 112px)}}.dashboard-menu__title{font-size:1.05rem;font-weight:800;color:var(--dash-ink);margin-bottom:12px}.dashboard-menu__group{display:flex;flex-direction:column;gap:8px}.dashboard-menu__group:not(:last-child){padding-bottom:12px;margin-bottom:12px;border-bottom:1px dashed #e2e8f0}.dashboard-menu__label{font-size:.8rem;font-weight:700;color:var(--dash-muted);text-transform:uppercase;letter-spacing:.08em}.dashboard-menu__item{position:relative;text-align:left;padding:10px 12px;border-radius:10px;border:1px solid rgba(0,0,0,0);background:rgba(248,250,252,.95);color:var(--dash-ink);font-size:.95rem;font-weight:700;cursor:pointer;transition:all .2s ease}.dashboard-menu__item:hover{border-color:rgba(59,130,246,.35);background:rgba(239,246,255,.95);color:#1e3a8a}.dashboard-menu__item.is-active{background:#1e40af;color:#fff;border-color:#1e40af;box-shadow:0 10px 18px rgba(30,64,175,.2)}.dashboard-menu__item.is-disabled{background:#f8fafc;color:#9ca3af;cursor:not-allowed;border-color:rgba(0,0,0,0)}.dashboard-detail{min-width:0;display:flex;flex-direction:column;gap:18px;padding:6px 0 36px}.dashboard-panel{display:none;background:#fff;border-radius:14px;border:1px solid rgba(148,163,184,.2);padding:24px 28px;box-shadow:0 10px 24px rgba(15,23,42,.06);position:relative}.dashboard-panel.is-active{display:block}.dashboard-panel__header{margin-bottom:16px;padding-bottom:14px;border-bottom:1px solid rgba(148,163,184,.2)}.dashboard-panel__eyebrow{font-size:.75rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--dash-soft);margin-bottom:6px}.dashboard-panel__title{font-size:1.8rem;font-weight:800;color:var(--dash-ink);margin-bottom:6px}.dashboard-panel__subtitle{color:var(--dash-muted);font-size:1rem}.dashboard-panel__actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:0;justify-content:flex-end}.dashboard-panel__body{display:flex;flex-direction:column;gap:18px}.dashboard-panel__top{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;flex-wrap:wrap}.drill-selector{display:flex;flex-direction:column;gap:16px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:16px;padding:20px 22px}.drill-selector__field{display:flex;flex-direction:column;gap:8px}.drill-selector__label{font-size:.95rem;font-weight:700;color:#1e293b}.drill-selector__control{position:relative}.drill-selector__select{width:100%;border:1px solid #cbd5f5;border-radius:12px;padding:10px 12px;background:#fff;font-size:1rem;font-weight:600;color:#0f172a}.drill-selector__select--hidden{position:absolute;opacity:0;pointer-events:none;height:0;width:0}.drill-selector__dropdown{position:relative}.drill-selector__trigger{width:100%;text-align:left;border:1px solid #cbd5f5;border-radius:12px;padding:10px 12px;background:#fff;font-size:1rem;font-weight:600;color:#0f172a;cursor:pointer;position:relative}.drill-selector__trigger::after{content:"";position:absolute;right:12px;top:50%;width:8px;height:8px;border-right:2px solid #475569;border-bottom:2px solid #475569;transform:translateY(-50%) rotate(45deg);transition:transform .2s ease}.drill-selector__dropdown.is-open .drill-selector__trigger::after{transform:translateY(-70%) rotate(-135deg)}.drill-selector__menu{position:absolute;left:0;right:0;top:calc(100% + 6px);background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:6px;box-shadow:0 16px 28px rgba(15,23,42,.12);max-height:360px;overflow-y:auto;opacity:0;pointer-events:none;transform:translateY(-6px);transition:opacity .2s ease,transform .2s ease;z-index:5}.drill-selector__dropdown.is-open .drill-selector__menu{opacity:1;pointer-events:auto;transform:translateY(0)}.drill-selector__option{width:100%;text-align:left;border:none;background:rgba(0,0,0,0);padding:8px 10px;border-radius:8px;font-weight:600;color:#0f172a;cursor:pointer}.drill-selector__option:hover{background:#eff6ff;color:#1d4ed8}.drill-selector__select:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px rgba(37,99,235,.16)}.drill-selector__options{display:flex;flex-direction:column;gap:6px}.drill-selector__mode{display:flex;flex-wrap:wrap;gap:10px 16px}.drill-selector__meta{font-size:.9rem;font-weight:700;color:#0f172a;padding:8px 12px;border:1px solid #e2e8f0;border-radius:10px;background:#fff;width:fit-content}.drill-selector__toggle{display:inline-flex;align-items:center;gap:10px;font-weight:700;color:#1e293b}.drill-selector__toggle input{width:18px;height:18px}.drill-selector__hint{margin:0;color:#64748b;font-size:.9rem}.drill-selector__actions{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.drill-selector__subtle{color:#94a3b8;border-color:#e2e8f0}.drill-selector__subtle:hover{color:#64748b;border-color:#cbd5f5}.dashboard-grid{display:flex;flex-direction:column;gap:32px}.subjects-list{display:flex;flex-direction:column;gap:28px}.subject-section{border-top:2px solid #dbeafe;padding-top:24px;padding-bottom:16px}.subject-section:first-child{border-top:none;padding-top:0}.subject-header{display:flex;align-items:center;margin-bottom:16px}.subject-title{font-size:2.2rem;font-weight:800;color:#0b1f3a;margin:0}.subject-body{display:flex;flex-direction:column;gap:20px}.activity-group{display:flex;flex-direction:column;gap:12px}.activity-group__title{font-size:1.32rem;font-weight:800;color:#1e3a8a;position:relative;padding-left:14px;letter-spacing:.01em}.activity-group__title::before{content:"";position:absolute;left:0;top:4px;width:4px;height:18px;border-radius:999px;background:#1e40af}.activity-row{display:grid;grid-template-columns:minmax(0, 1fr) 90px auto;align-items:center;gap:16px;padding:14px 0;border-bottom:1px solid #e2e8f0;transition:background .2s ease,transform .2s ease}.activity-row--available:hover{background:#f8fafc;transform:translateY(-1px)}.activity-row__info{display:flex;flex-direction:column;gap:4px}.activity-row__name{font-weight:800;color:#0b1f3a;font-size:1.18rem}.activity-row__desc{color:#475569;font-size:1.05rem}.activity-row__meta{color:#475569;font-size:1.02rem;text-align:right}.activity-row__actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}.activity-row.is-disabled{opacity:.6;pointer-events:none}.activity-row--clickable{border:1px solid #e2e8f0;border-radius:14px;padding:16px;background:#f8fafc;cursor:pointer;margin-bottom:10px;border-bottom:none}.activity-row--clickable:hover{background:#eff6ff;box-shadow:0 10px 20px rgba(30,64,175,.1)}.activity-row--clickable.activity-row--step{padding-left:20px}.activity-row--clickable.activity-row--step::before{left:10px;top:24px;bottom:24px}.activity-row__step-badge{display:inline-flex;align-items:center;gap:4px;font-size:.85rem;font-weight:800;color:#1e40af;background:#e0e7ff;padding:4px 10px;border-radius:999px;width:fit-content}.activity-row--step{position:relative;padding-left:16px}.activity-row--step::before{content:"";position:absolute;left:4px;top:20px;bottom:20px;width:2px;background:#c7d2fe;border-radius:999px}.action-btn{border:1px solid #c7d2fe;background:#1e40af;color:#fff;padding:9px 16px;border-radius:8px;font-weight:800;font-size:1.02rem;text-decoration:none;cursor:pointer;transition:background .2s ease,transform .2s ease}.action-btn:hover{background:#1d4ed8;transform:translateY(-1px)}.action-btn--ghost{background:#fff;color:#1e40af}.learnings-dashboard .action-btn{border-radius:999px;padding:10px 18px;border:1px solid rgba(59,130,246,.35);box-shadow:0 10px 18px rgba(30,64,175,.15)}.learnings-dashboard .action-btn--ghost{background:hsla(0,0%,100%,.95);color:#1e3a8a;box-shadow:none}.learnings-dashboard .action-btn--ghost:hover{background:rgba(239,246,255,.95)}.dashboard-panel.is-active{animation:dashboard-panel-in .45s ease}.dashboard-panel.is-active .dashboard-section,.dashboard-panel.is-active .dashboard-card,.dashboard-panel.is-active .resume-item,.dashboard-panel.is-active .summary-card{animation:dashboard-rise .5s ease both}.dashboard-panel.is-active .summary-card:nth-child(2){animation-delay:.04s}.dashboard-panel.is-active .summary-card:nth-child(3){animation-delay:.08s}.dashboard-panel.is-active .dashboard-card:nth-child(2){animation-delay:.05s}.dashboard-panel.is-active .dashboard-card:nth-child(3){animation-delay:.1s}.dashboard-panel.is-active .dashboard-card:nth-child(4){animation-delay:.15s}@keyframes dashboard-panel-in{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes dashboard-rise{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}@media(prefers-reduced-motion: reduce){.dashboard-panel.is-active,.dashboard-panel.is-active .dashboard-section,.dashboard-panel.is-active .dashboard-card,.dashboard-panel.is-active .resume-item,.dashboard-panel.is-active .summary-card{animation:none}}.chapter-accordion{margin-top:12px;opacity:0;transform:translateY(-10px);transition:all .3s ease;border:1px solid #e2e8f0;border-radius:12px;background:#fff;padding:14px;box-shadow:0 12px 24px rgba(15,23,42,.08)}.chapter-accordion__header{display:flex;align-items:baseline;justify-content:space-between;gap:12px;padding:8px 6px 14px}.chapter-accordion__title{font-size:1.12rem;font-weight:800;color:#0b1f3a}.chapter-accordion__hint{font-size:.95rem;color:#475569}.chapter-columns{display:grid;grid-template-columns:repeat(2, minmax(0, 1fr));gap:16px}@media(max-width: 767px){.chapter-columns{grid-template-columns:1fr}}.chapter-column{border:1px solid #1e40af;border-radius:10px;padding:16px;background:#fff;box-shadow:0 14px 28px rgba(30,64,175,.18);display:flex;flex-direction:column;gap:12px;position:relative;overflow:hidden}.chapter-column::after{content:"";position:absolute;inset:0;border-radius:10px;box-shadow:inset 0 0 0 1px rgba(30,64,175,.2);pointer-events:none}.chapter-column__title{display:flex;align-items:center;justify-content:space-between;font-weight:800;color:#1e40af;font-size:1.2rem;padding-bottom:6px;border-bottom:2px solid #1e40af}.chapter-column__link{font-size:.85rem;color:#1e3a8a;text-decoration:none;padding:4px 10px;border-radius:999px;background:#bfdbfe;border:1px solid #93c5fd}.chapter-column__link:hover{background:#93c5fd;color:#fff}.year-grid{display:flex;flex-direction:column;gap:24px;padding:18px;background:#f8fafc;border-radius:10px;border:1px solid #e2e8f0}.year-group-title{font-size:1rem;font-weight:600;color:#374151;margin:0 0 12px 0;padding-bottom:8px;border-bottom:2px solid #e5e7eb}.year-items{display:grid;grid-template-columns:repeat(auto-fill, minmax(92px, 1fr));gap:10px}.year-item{display:flex;flex-direction:column;align-items:center;padding:12px 8px;background:#fff;border:2px solid #e5e7eb;border-radius:8px;text-decoration:none;transition:all .2s ease;cursor:pointer}.year-item:hover{border-color:#3b82f6;background:#eff6ff;transform:translateY(-2px);box-shadow:0 6px 12px rgba(59,130,246,.2)}.year-item--disabled{background:#f9fafb;border-color:#d1d5db;opacity:.5;cursor:not-allowed}.year-item--disabled:hover{border-color:#d1d5db;background:#f9fafb;transform:none;box-shadow:none}.year-item--disabled .year-text{color:#9ca3af}.year-item--disabled .year-full{color:#9ca3af}.year-item .year-text{font-size:1.05rem;font-weight:700;color:#3b82f6;margin-bottom:4px}.year-item .year-full{font-size:.8rem;color:#6b7280;text-align:center}.chapter-list{display:grid;gap:8px;padding:10px;background:#fff;border-radius:8px;border:1px solid #1e40af;grid-template-columns:repeat(auto-fit, minmax(240px, 1fr))}.chapter-item{display:flex;align-items:center;justify-content:flex-start;padding:12px 14px;background:#fff;border-radius:6px;text-decoration:none;border:1px solid #1e40af;transition:all .2s ease}.chapter-item:hover{background:#1e40af;border-color:#1e40af;transform:translateX(4px)}.chapter-item:hover .chapter-title{color:#fff}.chapter-title{color:#1e40af;font-size:1.02rem;font-weight:700;text-align:left}.law-modal{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.5);display:none;justify-content:center;align-items:center;z-index:1000;backdrop-filter:blur(4px);opacity:0;transition:opacity .3s ease}.law-modal.show{display:flex;opacity:1}.law-modal__content{background:#fff;border-radius:16px;width:90%;max-width:900px;max-height:80vh;overflow:hidden;box-shadow:0 20px 60px rgba(0,0,0,.3);transform:scale(0.9);transition:transform .3s ease}.law-modal.show .law-modal__content{transform:scale(1)}@media(max-width: 767px){.law-modal__content{width:95%;max-height:85vh}}.law-modal__header{padding:24px;border-bottom:1px solid #e5e7eb;display:flex;align-items:center;justify-content:space-between;background:linear-gradient(135deg, #eff6ff 0%, #f8fafc 100%)}@media(max-width: 767px){.law-modal__header{padding:16px}}.law-modal__title{font-size:1.5rem;font-weight:700;color:#1f2937;margin:0;font-family:"Noto Serif JP",serif}@media(max-width: 767px){.law-modal__title{font-size:1.25rem}}.law-modal__close{width:32px;height:32px;border:none;background:#e5e7eb;color:#6b7280;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1.5rem;line-height:1;transition:all .2s ease}.law-modal__close:hover{background:#ef4444;color:#fff;transform:scale(1.1)}.law-modal__body{padding:24px;max-height:60vh;overflow-y:auto}@media(max-width: 767px){.law-modal__body{padding:16px;max-height:65vh}}.law-modal-grid{display:grid;grid-template-columns:repeat(auto-fit, minmax(260px, 1fr));gap:18px}@media(max-width: 767px){.law-modal-grid{grid-template-columns:1fr;gap:16px}}.law-modal-group{background:var(--dash-surface);border-radius:16px;padding:18px 18px 16px;border:1px solid var(--dash-border);box-shadow:0 12px 22px rgba(15,23,42,.06);position:relative;overflow:hidden}.law-modal-group::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg, rgba(29, 78, 216, 0.6), rgba(14, 165, 233, 0.35), rgba(255, 255, 255, 0))}.law-modal-group.is-hidden{display:none}.law-modal-group__title{font-size:.8rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--dash-soft);margin:2px 0 12px 0}.law-modal-items{display:flex;flex-direction:column;gap:8px}.law-list-filter{display:flex;flex-direction:column;gap:12px;margin-bottom:14px}.law-list-filter__search{display:flex;flex-direction:column;gap:8px}.law-list-filter__label{font-size:.78rem;font-weight:700;color:var(--dash-soft);letter-spacing:.08em;text-transform:uppercase}.law-list-filter__input{display:flex;align-items:center;gap:8px;padding:10px 12px;background:#fff;border:1px solid var(--dash-border);border-radius:12px;box-shadow:0 10px 18px rgba(15,23,42,.06);transition:border-color .2s ease,box-shadow .2s ease}.law-list-filter__input:focus-within{border-color:rgba(29,78,216,.45);box-shadow:0 0 0 3px rgba(29,78,216,.12)}.law-list-filter__icon{font-size:.9rem;color:var(--dash-soft)}.law-list-filter__field{flex:1;border:none;outline:none;background:rgba(0,0,0,0);font-size:.95rem;font-weight:600;color:var(--dash-ink)}.law-list-filter__field::placeholder{color:var(--dash-soft);font-weight:500}.law-list-filter__clear{border:none;background:rgba(148,163,184,.14);color:var(--dash-muted);font-size:.75rem;font-weight:700;padding:6px 10px;border-radius:999px;cursor:pointer;transition:background .2s ease,color .2s ease}.law-list-filter__clear:hover{background:rgba(29,78,216,.15);color:var(--dash-accent)}.law-list-filter__chips{display:flex;flex-wrap:wrap;gap:8px}.law-list-filter__chip{border:1px solid rgba(148,163,184,.4);background:#fff;color:var(--dash-muted);font-size:.75rem;font-weight:700;padding:6px 12px;border-radius:999px;cursor:pointer;transition:background .2s ease,border-color .2s ease,color .2s ease,transform .2s ease}.law-list-filter__chip:hover{transform:translateY(-1px);border-color:rgba(29,78,216,.4);color:var(--dash-accent)}.law-list-filter__chip.is-active{background:rgba(29,78,216,.12);border-color:rgba(29,78,216,.4);color:var(--dash-accent)}.law-list-filter__meta{display:flex;align-items:center;justify-content:space-between;gap:12px;font-size:.8rem;color:var(--dash-muted);font-weight:600}.law-list-filter__count strong{color:var(--dash-accent-strong)}.law-list-filter__hint{color:var(--dash-soft)}.law-list-filter__empty{display:none;padding:12px 14px;border-radius:12px;border:1px dashed rgba(148,163,184,.6);color:var(--dash-soft);font-size:.85rem;font-weight:600;background:rgba(248,250,252,.9)}.law-list-filter__empty.is-visible{display:block}.chapter-stack{display:flex;flex-direction:column;gap:20px}.chapter-block{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;padding:16px}.chapter-block__title{font-size:1rem;font-weight:700;color:#1e3a8a;margin-bottom:12px}.law-modal-item{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;background:#fff;border:1px solid rgba(148,163,184,.28);border-radius:12px;text-decoration:none;color:var(--dash-ink);font-size:.95rem;font-weight:600;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease,background .2s ease;position:relative;overflow:hidden}.law-modal-item:hover{background:#f8fbff;border-color:rgba(29,78,216,.35);color:var(--dash-ink);transform:translateY(-2px);box-shadow:0 12px 20px rgba(15,23,42,.08)}.law-modal-item:hover .problem-count{background:rgba(29,78,216,.22);color:#1e3a8a;border-color:rgba(29,78,216,.35)}.law-modal-item:active{transform:translateY(0);background:#eff6ff}.law-modal-item .law-name{flex:1;text-align:left;min-width:0;line-height:1.4;font-weight:700}.law-modal-item .problem-count{background:rgba(29,78,216,.12);color:#1e3a8a;padding:4px 10px;border-radius:999px;font-size:.75rem;font-weight:700;transition:background .2s ease,color .2s ease,border-color .2s ease;min-width:44px;text-align:center;border:1px solid rgba(29,78,216,.22);white-space:nowrap}.law-modal-item.is-hidden{display:none}.settings-form{display:flex;flex-direction:column;gap:20px}.settings-form__section{display:flex;flex-direction:column;gap:10px}.settings-form__control{position:relative}.settings-form__grid{display:grid;grid-template-columns:repeat(2, minmax(0, 1fr));gap:16px}@media(max-width: 767px){.settings-form__grid{grid-template-columns:1fr}}.settings-form__label{font-weight:700;color:#0f172a;font-size:1rem}.settings-form__row{display:flex;flex-wrap:wrap;gap:12px}.settings-form__option{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border-radius:10px;border:1px solid #e2e8f0;background:#f8fafc;color:#1e293b;font-size:.95rem}.settings-form__option--toggle{cursor:pointer;border:none;padding:0;background:rgba(0,0,0,0)}.settings-form__option--toggle input{position:absolute;opacity:0;pointer-events:none}.settings-form__option--chapter{width:100%;padding:0;border:none;background:rgba(0,0,0,0)}.settings-form__option--chapter input{position:absolute;opacity:0;pointer-events:none}.settings-form__choice-label{display:inline-flex;align-items:center;justify-content:center;padding:8px 16px;border-radius:999px;border:1px solid #bfdbfe;background:#eff6ff;color:#1e3a8a;font-weight:700;font-size:.95rem;transition:all .2s ease}.settings-form__option--toggle input:checked+.settings-form__choice-label{background:#1e40af;border-color:#1e40af;color:#fff;box-shadow:0 6px 12px rgba(30,64,175,.2)}.settings-form__option--chapter input:checked+.settings-form__choice-label--chapter{border-color:#94a3b8;background:#f1f5f9;color:#0f172a}.settings-form__option--chapter input:checked+.settings-form__choice-label--chapter::before{background:#0f172a;border-color:#0f172a}.settings-form__option--chapter input:checked+.settings-form__choice-label--chapter::after{border-right-color:#fff;border-bottom-color:#fff}.settings-form__option--chapter input:focus+.settings-form__choice-label--chapter{box-shadow:0 0 0 3px rgba(30,64,175,.16)}.settings-form__option--toggle input:focus+.settings-form__choice-label{box-shadow:0 0 0 3px rgba(30,64,175,.2)}.settings-form__choice-label--count{min-width:64px;justify-content:center}.settings-form__choice-label--chapter{position:relative;font-size:.9rem;padding:9px 12px 9px 36px;border-radius:12px;border:1px solid #e2e8f0;background:#fff;color:#0f172a;font-weight:600;width:100%;justify-content:flex-start;transition:border-color .2s ease,box-shadow .2s ease,transform .2s ease}.settings-form__choice-label--chapter::before{content:"";position:absolute;left:12px;top:50%;width:14px;height:14px;border:2px solid #cbd5f5;border-radius:5px;transform:translateY(-50%);background:#fff}.settings-form__choice-label--chapter::after{content:"";position:absolute;left:16px;top:50%;width:6px;height:10px;border-right:2px solid rgba(0,0,0,0);border-bottom:2px solid rgba(0,0,0,0);transform:translateY(-60%) rotate(45deg)}.settings-form__choice-label--chapter:hover{border-color:#cbd5f5;box-shadow:0 8px 16px rgba(15,23,42,.06);transform:translateY(-1px)}.settings-form__chapter-list{display:grid;gap:16px;border:1px solid #e2e8f0;border-radius:12px;padding:12px;background:#f8fafc}.settings-form__chapter-group{display:flex;flex-direction:column;gap:10px}.settings-form__accordion{border:1px solid #e2e8f0;border-radius:14px;padding:10px 12px;background:#f8fafc}.settings-form__summary{font-weight:700;color:#1e3a8a;font-size:.95rem;cursor:pointer;list-style:none;display:flex;align-items:center;justify-content:space-between;gap:10px;padding:8px 4px}.settings-form__summary::after{content:"";width:6px;height:6px;border-right:2px solid #64748b;border-bottom:2px solid #64748b;transform:rotate(45deg);transition:transform .2s ease}.settings-form__summary-meta{font-size:.8rem;font-weight:600;color:#64748b}.settings-form__accordion[open] .settings-form__summary::after{transform:rotate(-135deg)}.settings-form__accordion-content{margin-top:10px;padding:10px;border-radius:12px;background:#fff;border:1px solid #e2e8f0;box-shadow:0 10px 20px rgba(15,23,42,.06)}.settings-form__chapter-grid{display:grid;grid-template-columns:1fr;gap:8px}.settings-form__chapter-scroll{max-height:220px;overflow:auto;padding-right:6px}.settings-form__select{width:100%;border:1px solid #bfdbfe;background:#eff6ff;color:#1e293b;border-radius:10px;padding:10px 12px;font-size:1rem;font-weight:600}.settings-form__select--hidden{position:absolute;opacity:0;pointer-events:none;height:0;width:0}.settings-form__trigger{width:100%;text-align:left;border:1px solid #cbd5f5;border-radius:12px;padding:10px 12px;background:#fff;font-size:1rem;font-weight:600;color:#0f172a;cursor:pointer;position:relative}.settings-form__trigger::after{content:"";position:absolute;right:12px;top:50%;width:8px;height:8px;border-right:2px solid #475569;border-bottom:2px solid #475569;transform:translateY(-50%) rotate(45deg);transition:transform .2s ease}.settings-form__control.is-open .settings-form__trigger::after{transform:translateY(-70%) rotate(-135deg)}.settings-form__menu{position:absolute;left:0;right:0;top:calc(100% + 6px);background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:6px;box-shadow:0 16px 28px rgba(15,23,42,.12);max-height:240px;overflow-y:auto;opacity:0;pointer-events:none;transform:translateY(-6px);transition:opacity .2s ease,transform .2s ease;z-index:5}.settings-form__control.is-open .settings-form__menu{opacity:1;pointer-events:auto;transform:translateY(0)}.settings-form__menu-option{width:100%;text-align:left;border:none;background:rgba(0,0,0,0);padding:8px 10px;border-radius:8px;font-weight:600;color:#0f172a;cursor:pointer}.settings-form__menu-option:hover{background:#eff6ff;color:#1d4ed8}.settings-form__count{max-width:220px}.settings-form__input{width:100%;border:1px solid #bfdbfe;background:#fff;color:#1e293b;border-radius:10px;padding:10px 12px;font-size:1rem;font-weight:600}.settings-form__actions{display:flex;justify-content:flex-end;gap:12px}.result-page{min-height:100vh;background:#f8fafc;font-family:"Noto Sans JP",sans-serif;line-height:1.6;color:#1f2937}.result-header{background:#fff;border-bottom:2px solid #e5e7eb;padding:20px 0;box-shadow:0 2px 10px rgba(0,0,0,.05)}.result-header__content{max-width:1200px;margin:0 auto;padding:0 20px;text-align:center}@media(max-width: 767px){.result-header__content{padding:0 16px}}.result-header__title{font-size:1.5rem;font-weight:700;color:#111827;margin:0}@media(max-width: 767px){.result-header__title{font-size:1.25rem}}.result-container{max-width:1600px;margin:40px auto;padding:0 30px}@media(max-width: 767px){.result-container{margin:20px auto;padding:0 16px}}.result-summary{background:#fff;border-radius:16px;padding:40px;margin-bottom:40px;box-shadow:0 10px 25px rgba(0,0,0,.08);border:1px solid #e5e7eb}@media(max-width: 767px){.result-summary{padding:24px;margin-bottom:24px;border-radius:12px}}.result-summary__score{text-align:center;margin-bottom:20px;padding:15px;background:#f9fafb;border-radius:8px;border:1px solid #e5e7eb}@media(max-width: 767px){.result-summary__score{margin-bottom:16px;padding:12px}}.result-summary__percentage{font-size:2rem;font-weight:700;color:#374151;margin-bottom:5px;display:block}@media(max-width: 767px){.result-summary__percentage{font-size:1.5rem}}.result-summary__fraction{font-size:1rem;color:#6b7280;font-weight:600}.result-summary__details{display:grid;grid-template-columns:repeat(auto-fit, minmax(150px, 1fr));gap:24px;margin-bottom:40px;padding:24px;background:#f9fafb;border-radius:12px;border:1px solid #f3f4f6}@media(max-width: 767px){.result-summary__details{grid-template-columns:1fr;gap:16px;margin-bottom:24px;padding:20px}}.result-detail{text-align:center}.result-detail__label{display:block;font-size:.875rem;color:#6b7280;font-weight:600;margin-bottom:8px;text-transform:uppercase;letter-spacing:.5px}.result-detail__value{font-size:1.5rem;color:#111827;font-weight:800}@media(max-width: 767px){.result-detail__value{font-size:1.25rem}}.result-actions{display:flex;gap:16px;justify-content:center}@media(max-width: 767px){.result-actions{flex-direction:column;gap:12px}}.result-btn{padding:14px 28px;border-radius:10px;font-weight:700;font-size:1rem;text-decoration:none;text-align:center;transition:all .3s ease;border:2px solid;min-width:160px}@media(max-width: 767px){.result-btn{padding:12px 24px;min-width:auto}}.result-btn--primary{background:#3b82f6;color:#fff;border-color:#3b82f6}.result-btn--primary:hover{background:#2563eb;border-color:#2563eb;transform:translateY(-2px);box-shadow:0 8px 20px rgba(59,130,246,.3)}.result-btn--secondary{background:#fff;color:#374151;border-color:#d1d5db}.result-btn--secondary:hover{background:#f9fafb;border-color:#9ca3af;transform:translateY(-2px);box-shadow:0 8px 20px rgba(0,0,0,.1)}.result-section-title{font-size:2.25rem;font-weight:700;color:#111827;text-align:center;margin:50px 0 30px 0;padding-bottom:15px;border-bottom:3px solid #e5e7eb}@media(max-width: 767px){.result-section-title{font-size:1.875rem;margin:30px 0 20px 0}}.result-review{margin-bottom:40px}@media(max-width: 767px){.result-review{padding:24px;margin-bottom:24px;border-radius:12px}}.result-review__title{font-size:2rem;font-weight:700;color:#111827;margin:0 0 40px 0;padding-bottom:20px;border-bottom:3px solid #e5e7eb;text-align:center}@media(max-width: 767px){.result-review__title{font-size:1.5rem;margin-bottom:20px}}.result-content-level1{padding:40px}@media(max-width: 767px){.result-content-level1{padding:24px}}.result-content-level1 .status-mark{display:inline-block;width:24px;height:24px;border-radius:50%;color:#fff;font-size:12px;font-weight:900;margin-left:4px;text-align:center;line-height:24px;vertical-align:top;border:3px solid #fff;box-shadow:0 2px 8px rgba(0,0,0,.15)}.result-content-level1 .status-mark--correct{background:#22c55e}.result-content-level1 .status-mark--incorrect,.result-content-level1 .status-mark--unanswered{background:#ef4444}.result-content-level1 .status-mark--unanswered{margin-left:-4px;z-index:10;position:relative}.result-content-level1 .chapter-title{font-size:2rem;font-weight:700;color:#1e40af;margin-bottom:30px;text-align:center;font-family:"Noto Serif JP",serif}@media(max-width: 767px){.result-content-level1 .chapter-title{font-size:1.5rem;margin-bottom:20px}}.result-content-level1 .chapter-content{line-height:2.5rem;font-size:1.2rem;color:#374151}@media(max-width: 767px){.result-content-level1 .chapter-content{font-size:1rem}}.result-content-level1 .chapter-content p{margin-bottom:1.5rem;display:inline}.result-content-level1 .chapter-content p+p{display:block;margin-top:1.5rem}.result-content-level1 .chapter-content h2,.result-content-level1 .chapter-content h3,.result-content-level1 .chapter-content h4{font-family:"Noto Serif JP",serif;font-weight:700;margin-top:2rem;margin-bottom:1rem;color:#1f2937}.result-content-level1 .chapter-content h2{font-size:1.5rem;border-bottom:2px solid #d1d5db;padding-bottom:8px}.result-content-level1 .chapter-content h3{font-size:1.25rem}.result-content-level1 .chapter-content ul,.result-content-level1 .chapter-content ol{list-style:none;padding-left:2rem}.result-content-level1 .chapter-content ul li,.result-content-level1 .chapter-content ol li{margin-bottom:.75rem}.result-content-level1 .chapter-content .blank-wrapper{position:relative;display:inline;margin:0 2px}.result-content-level1 .chapter-content .blank-wrapper:hover .blank-details{display:block;opacity:1;transform:translateX(-50%) translateY(0)}.result-content-level1 .chapter-content .blank-input{font-size:1.1rem;padding:6px 12px;margin:0;background:#fff;border:2px solid #d1d5db;border-radius:6px;text-align:center;font-weight:700;color:#374151;cursor:default;min-width:80px;max-width:150px;position:relative;vertical-align:middle}.result-content-level1 .chapter-content .blank-input.unanswered{background:#fef2f2;border-color:#ef4444;color:#dc2626}.result-content-level1 .chapter-content .blank-input.correct{background:#f0fdf4;border-color:#22c55e;color:#166534;box-shadow:0 4px 12px rgba(34,197,94,.2)}.result-content-level1 .chapter-content .blank-input.incorrect{background:#fef2f2;border-color:#ef4444;color:#dc2626;box-shadow:0 4px 12px rgba(239,68,68,.2)}.result-content-level1 .chapter-content .blank-details{position:absolute;top:100%;left:50%;transform:translateX(-50%);background:#fff;border:2px solid;border-radius:8px;padding:12px;margin-top:8px;min-width:200px;box-shadow:0 8px 24px rgba(0,0,0,.15);z-index:10;font-size:.875rem;font-weight:600;display:none;opacity:0;transition:opacity .3s ease,transform .3s ease;transform:translateX(-50%) translateY(-10px)}.result-content-level1 .chapter-content .blank-details--correct{border-color:#22c55e;background:#f0fdf4;color:#166534}.result-content-level1 .chapter-content .blank-details--incorrect{border-color:#ef4444;background:#fef2f2;color:#dc2626}.result-content-level1 .chapter-content .blank-details__user{margin-bottom:6px;padding-bottom:6px;border-bottom:1px solid rgba(0,0,0,.1)}.result-content-level1 .chapter-content .blank-details__correct{color:#059669;font-weight:700}.result-content-level1 .chapter-content .blank-details__status{position:absolute;top:-8px;right:8px;width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:900;background:#fff;border:2px solid}.result-content-level1 .chapter-content .blank-details__status--correct{background:#22c55e;border-color:#22c55e;color:#fff}.result-content-level1 .chapter-content .blank-details__status--incorrect{background:#ef4444;border-color:#ef4444;color:#fff}.result-content-level1 .chapter-content .blank-details::before{content:"";position:absolute;bottom:100%;left:50%;transform:translateX(-50%);border-left:8px solid rgba(0,0,0,0);border-right:8px solid rgba(0,0,0,0);border-bottom:8px solid}.result-content-level1 .chapter-content .blank-details--correct::before{border-bottom-color:#22c55e}.result-content-level1 .chapter-content .blank-details--incorrect::before{border-bottom-color:#ef4444}.result-page{min-height:100vh;background:#f8fafc;font-family:"Noto Sans JP",sans-serif;line-height:1.6;color:#1f2937}.result-header{background:#fff;border-bottom:2px solid #e5e7eb;padding:20px 0;box-shadow:0 2px 10px rgba(0,0,0,.05)}.result-header__content{max-width:1200px;margin:0 auto;padding:0 20px;text-align:center}@media(max-width: 767px){.result-header__content{padding:0 16px}}.result-header__title{font-size:1.5rem;font-weight:700;color:#111827;margin:0}@media(max-width: 767px){.result-header__title{font-size:1.25rem}}.result-container{max-width:1600px;margin:40px auto;padding:0 30px}@media(max-width: 767px){.result-container{margin:20px auto;padding:0 16px}}.result-summary{background:#fff;border-radius:16px;padding:40px;margin-bottom:40px;box-shadow:0 10px 25px rgba(0,0,0,.08);border:1px solid #e5e7eb}@media(max-width: 767px){.result-summary{padding:24px;margin-bottom:24px;border-radius:12px}}.result-summary__score{text-align:center;margin-bottom:20px;padding:15px;background:#f9fafb;border-radius:8px;border:1px solid #e5e7eb}@media(max-width: 767px){.result-summary__score{margin-bottom:16px;padding:12px}}.result-summary__percentage{font-size:2rem;font-weight:700;color:#374151;margin-bottom:5px;display:block}@media(max-width: 767px){.result-summary__percentage{font-size:1.5rem}}.result-summary__fraction{font-size:1rem;color:#6b7280;font-weight:600}.result-summary__rate{font-size:.9rem;color:#64748b;font-weight:600;margin-top:4px}.result-summary__details{display:grid;grid-template-columns:repeat(auto-fit, minmax(150px, 1fr));gap:24px;margin-bottom:40px;padding:24px;background:#f9fafb;border-radius:12px;border:1px solid #f3f4f6}@media(max-width: 767px){.result-summary__details{grid-template-columns:1fr;gap:16px;margin-bottom:24px;padding:20px}}.result-detail{text-align:center}.result-detail__label{display:block;font-size:.875rem;color:#6b7280;font-weight:600;margin-bottom:8px;text-transform:uppercase;letter-spacing:.5px}.result-detail__value{font-size:1.5rem;color:#111827;font-weight:800}@media(max-width: 767px){.result-detail__value{font-size:1.25rem}}.result-actions{display:flex;gap:16px;justify-content:center}@media(max-width: 767px){.result-actions{flex-direction:column;gap:12px}}.result-btn{padding:14px 28px;border-radius:10px;font-weight:700;font-size:1rem;text-decoration:none;text-align:center;transition:all .3s ease;border:2px solid;min-width:160px}@media(max-width: 767px){.result-btn{padding:12px 24px;min-width:auto}}.result-btn--primary{background:#3b82f6;color:#fff;border-color:#3b82f6}.result-btn--primary:hover{background:#2563eb;border-color:#2563eb;transform:translateY(-2px);box-shadow:0 8px 20px rgba(59,130,246,.3)}.result-btn--secondary{background:#fff;color:#374151;border-color:#d1d5db}.result-btn--secondary:hover{background:#f9fafb;border-color:#9ca3af;transform:translateY(-2px);box-shadow:0 8px 20px rgba(0,0,0,.1)}.result-section-title{font-size:2.25rem;font-weight:700;color:#111827;text-align:center;margin:50px 0 30px 0;padding-bottom:15px;border-bottom:3px solid #e5e7eb}@media(max-width: 767px){.result-section-title{font-size:1.875rem;margin:30px 0 20px 0}}.result-review{margin-bottom:40px}@media(max-width: 767px){.result-review{padding:24px;margin-bottom:24px;border-radius:12px}}.result-review__title{font-size:2rem;font-weight:700;color:#111827;margin:0 0 40px 0;padding-bottom:20px;border-bottom:3px solid #e5e7eb;text-align:center}@media(max-width: 767px){.result-review__title{font-size:1.5rem;margin-bottom:20px}}.result-content-level2{padding:40px}@media(max-width: 767px){.result-content-level2{padding:24px}}.result-content-level2 .status-mark{display:inline-block;width:20px;height:20px;border-radius:50%;color:#fff;font-size:11px;font-weight:900;margin-left:4px;text-align:center;line-height:20px;vertical-align:top;border:2px solid #fff;box-shadow:0 2px 8px rgba(0,0,0,.15)}.result-content-level2 .status-mark--correct{background:#22c55e}.result-content-level2 .status-mark--incorrect,.result-content-level2 .status-mark--unanswered{background:#ef4444}.result-content-level2 .status-mark--unanswered{margin-left:-4px;z-index:10;position:relative}.result-content-level2 .chapter-title{font-size:2rem;font-weight:700;color:#6366f1;margin-bottom:30px;text-align:center;font-family:"Noto Serif JP",serif}@media(max-width: 767px){.result-content-level2 .chapter-title{font-size:1.5rem;margin-bottom:20px}}.result-content-level2 .chapter-content{line-height:2.6rem;font-size:1.1rem;color:#374151}@media(max-width: 767px){.result-content-level2 .chapter-content{font-size:1rem;line-height:2rem}}.result-content-level2 .chapter-content p{margin-bottom:1.2rem;display:inline}.result-content-level2 .chapter-content p+p{display:block;margin-top:1.2rem}.result-content-level2 .chapter-content h2,.result-content-level2 .chapter-content h3,.result-content-level2 .chapter-content h4{font-family:"Noto Serif JP",serif;font-weight:700;margin-top:1.8rem;margin-bottom:.8rem;color:#1f2937}.result-content-level2 .chapter-content h2{font-size:1.4rem;border-bottom:2px solid #d1d5db;padding-bottom:6px}.result-content-level2 .chapter-content h3{font-size:1.2rem}.result-content-level2 .chapter-content ul,.result-content-level2 .chapter-content ol{list-style:none;padding-left:1.5rem}.result-content-level2 .chapter-content ul li,.result-content-level2 .chapter-content ol li{margin-bottom:.6rem}.result-content-level2 .chapter-content .blank-wrapper{position:relative;display:inline;margin:0 2px}.result-content-level2 .chapter-content .blank-wrapper:hover .blank-details{display:block;opacity:1;transform:translateX(-50%) translateY(0)}.result-content-level2 .chapter-content .blank-input{font-size:1rem;padding:4px 10px;margin:0;background:#fff;border:2px dotted #d1d5db;border-radius:4px;text-align:center;font-weight:600;color:#374151;cursor:default;min-width:70px;max-width:140px;position:relative;vertical-align:middle;font-family:"Noto Serif JP",serif}.result-content-level2 .chapter-content .blank-input.unanswered{background:#fef2f2;border-color:#ef4444;color:#dc2626}.result-content-level2 .chapter-content .blank-input.correct{background:#f0fdf4;border:2px solid #22c55e;color:#166534;box-shadow:0 3px 10px rgba(34,197,94,.2)}.result-content-level2 .chapter-content .blank-input.incorrect{background:#fef2f2;border:2px solid #ef4444;color:#dc2626;box-shadow:0 3px 10px rgba(239,68,68,.2)}.result-content-level2 .chapter-content .blank-score-inline{display:inline-block;margin-left:6px;font-size:.62rem;font-weight:600;color:#94a3b8;letter-spacing:.03em;vertical-align:super}.result-content-level2 .chapter-content .blank-details{position:absolute;top:100%;left:50%;transform:translateX(-50%);background:#fff;border:2px solid;border-radius:6px;padding:10px;margin-top:6px;min-width:180px;box-shadow:0 6px 20px rgba(0,0,0,.15);z-index:10;font-size:.8rem;font-weight:600;display:none;opacity:0;transition:opacity .3s ease,transform .3s ease;transform:translateX(-50%) translateY(-8px)}.result-content-level2 .chapter-content .blank-details--correct{border-color:#22c55e;background:#f0fdf4;color:#166534}.result-content-level2 .chapter-content .blank-details--incorrect{border-color:#ef4444;background:#fef2f2;color:#dc2626}.result-content-level2 .chapter-content .blank-details__user{margin-bottom:5px;padding-bottom:5px;border-bottom:1px solid rgba(0,0,0,.1)}.result-content-level2 .chapter-content .blank-details__correct{color:#059669;font-weight:700}.result-content-level2 .chapter-content .blank-details__score{margin-top:4px;font-size:.75rem;font-weight:700;color:#1e293b}.result-content-level2 .chapter-content .blank-details__status{position:absolute;top:-6px;right:6px;width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:900;background:#fff;border:2px solid}.result-content-level2 .chapter-content .blank-details__status--correct{background:#22c55e;border-color:#22c55e;color:#fff}.result-content-level2 .chapter-content .blank-details__status--incorrect{background:#ef4444;border-color:#ef4444;color:#fff}.result-content-level2 .chapter-content .blank-details::before{content:"";position:absolute;bottom:100%;left:50%;transform:translateX(-50%);border-left:6px solid rgba(0,0,0,0);border-right:6px solid rgba(0,0,0,0);border-bottom:6px solid}.result-content-level2 .chapter-content .blank-details--correct::before{border-bottom-color:#22c55e}.result-content-level2 .chapter-content .blank-details--incorrect::before{border-bottom-color:#ef4444}.drill-level1-history{min-height:100vh;background:linear-gradient(180deg, #eff6ff 0%, #f8fafc 60%, #ffffff 100%)}.history-main{padding:40px 0}.history-main__container{max-width:980px;margin:0 auto;padding:0 .25rem}@media(min-width: 1024px){.history-main__container{padding:0 .5rem}}.history-main h2{font-size:1.4rem;font-weight:800;color:#0b1f3a;margin-bottom:20px;text-align:left}@media(max-width: 767px){.history-main h2{font-size:1.2rem;margin-bottom:16px}}.history-trend{background:#fff;border-radius:18px;border:1px solid #e2e8f0;box-shadow:0 18px 30px rgba(15,23,42,.08);padding:20px 22px 24px;margin-bottom:28px}.history-trend__header{display:flex;align-items:flex-start;justify-content:space-between;gap:20px;margin-bottom:16px}@media(max-width: 767px){.history-trend__header{flex-direction:column;align-items:flex-start}}.history-trend__eyebrow{font-size:.7rem;text-transform:uppercase;letter-spacing:.2em;font-weight:700;color:#94a3b8;margin-bottom:6px}.history-trend__header h2{min-height:2.6rem;line-height:1.3}.history-trend__meta{display:flex;gap:18px;flex-wrap:wrap}.history-trend__controls{display:flex;align-items:center;gap:6px;font-size:.85rem;color:#475569;position:relative}.history-trend__trigger{appearance:none;border:1px solid #cbd5f5;border-radius:999px;padding:8px 16px;background-color:#fff;color:#1e293b;font-weight:600;display:inline-flex;align-items:center;gap:8px;cursor:pointer;box-shadow:0 8px 18px rgba(15,23,42,.08);transition:border-color .2s ease,box-shadow .2s ease}.history-trend__trigger:hover{border-color:#94a3b8}.history-trend__trigger:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px rgba(37,99,235,.16)}.history-trend__trigger-icon{font-size:.7rem;color:#64748b}.history-trend__menu{position:absolute;right:0;top:calc(100% + 8px);min-width:220px;background:#fff;border:1px solid #e2e8f0;border-radius:12px;box-shadow:0 18px 30px rgba(15,23,42,.18);padding:6px;display:none;z-index:10}.history-trend__controls.is-open .history-trend__menu{display:block}.history-trend__option{width:100%;text-align:left;border:none;background:rgba(0,0,0,0);padding:8px 10px;border-radius:8px;font-weight:600;color:#0f172a;cursor:pointer}.history-trend__option:hover{background:#eff6ff;color:#1d4ed8}.history-trend__option.is-selected{background:#1d4ed8;color:#fff}.history-trend__stat{display:flex;flex-direction:column;gap:4px;font-size:.8rem;color:#64748b}.history-trend__stat strong{font-size:1.05rem;color:#0f172a}.history-trend__chart{background:#fff;border-radius:16px;border:1px solid #e2e8f0;padding:16px 16px 10px;min-height:320px;display:flex;align-items:center;justify-content:center;flex-direction:column}.history-trend__chart-canvas{width:100%;height:300px}.history-trend__empty{font-size:.9rem;color:#94a3b8;font-weight:700}.history-recent{margin-bottom:28px}.history-recent__header{display:flex;align-items:flex-start;justify-content:space-between;gap:20px;margin-bottom:16px}@media(max-width: 767px){.history-recent__header{flex-direction:column;align-items:flex-start}}.history-recent__eyebrow{font-size:.7rem;text-transform:uppercase;letter-spacing:.2em;font-weight:700;color:#94a3b8;margin-bottom:6px}.history-recent__meta{font-size:.85rem;font-weight:700;color:#475569;background:#e2e8f0;padding:6px 12px;border-radius:999px}.history-recent__grid{display:grid;grid-template-columns:repeat(auto-fit, minmax(240px, 1fr));gap:16px}.history-recent__card{display:flex;flex-direction:column;gap:10px;padding:16px;border-radius:16px;border:1px solid #e2e8f0;background:#fff;box-shadow:0 16px 28px rgba(15,23,42,.08);text-decoration:none;color:inherit;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease}.history-recent__card:hover{transform:translateY(-2px);box-shadow:0 18px 30px rgba(15,23,42,.14);border-color:#cbd5f5}.history-recent__card.is-disabled{background:#f8fafc;box-shadow:none;border-style:dashed;cursor:default}.history-recent__card-top{display:flex;justify-content:space-between;gap:12px;font-size:.8rem;color:#64748b;font-weight:700}.history-recent__chapter{text-transform:uppercase;letter-spacing:.12em}.history-recent__time{font-weight:600}.history-recent__title{font-size:1rem;font-weight:800;color:#0f172a}.history-recent__stats{display:grid;grid-template-columns:repeat(auto-fit, minmax(90px, 1fr));gap:10px;font-size:.85rem;color:#475569}.history-recent__stat{display:flex;flex-direction:column;gap:2px}.history-recent__stat strong{font-size:.95rem;color:#0f172a}.history-recent__cta{font-size:.85rem;font-weight:700;color:#1d4ed8}.history-recent__card.is-disabled .history-recent__cta{color:#94a3b8}.history-recent__empty{padding:20px;background:#fff;border-radius:14px;border:1px dashed #e2e8f0;color:#94a3b8;font-weight:700;text-align:center}.history-chapters__grid{display:grid;grid-template-columns:repeat(auto-fit, minmax(280px, 1fr));gap:20px}.chapter-card{background:#fff;border-radius:16px;border:1px solid #e2e8f0;box-shadow:0 18px 30px rgba(15,23,42,.08);padding:18px 18px 16px;display:flex;flex-direction:column;gap:12px}.chapter-card__header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.chapter-card__eyebrow{font-size:.75rem;font-weight:700;color:#64748b;text-transform:uppercase;letter-spacing:.12em}.chapter-card__title{font-size:1.05rem;font-weight:800;color:#0f172a;margin:4px 0 0}.chapter-card__badge{padding:6px 12px;border-radius:999px;font-size:.75rem;font-weight:700;white-space:nowrap;background:#e2e8f0;color:#475569}.chapter-card__badge--excellent{background:rgba(30,64,175,.14);color:#1e3a8a}.chapter-card__badge--good{background:rgba(59,130,246,.16);color:#1d4ed8}.chapter-card__badge--needs-review{background:rgba(14,165,233,.18);color:#0284c7}.chapter-card__badge--neglected{background:rgba(148,163,184,.2);color:#475569}.chapter-card__badge--none{background:#f1f5f9;color:#94a3b8}.chapter-card__body{display:grid;grid-template-columns:1fr auto;align-items:center;gap:12px}@media(max-width: 767px){.chapter-card__body{grid-template-columns:1fr}}.chapter-card__sparkline{min-height:56px;display:flex;align-items:center;justify-content:center;background:#f8fafc;border-radius:12px;border:1px dashed #e2e8f0;padding:6px 10px}.chapter-card__sparkline svg{width:100%;height:44px}.chapter-card__sparkline-empty{font-size:.85rem;color:#94a3b8;font-weight:700}.sparkline{stroke-width:3;stroke:#94a3b8}.sparkline--excellent{stroke:#1e3a8a}.sparkline--good{stroke:#2563eb}.sparkline--needs-review{stroke:#0ea5e9}.sparkline--neglected{stroke:#94a3b8}.chapter-card__stats{display:grid;grid-template-columns:1fr;gap:8px;min-width:130px}.chapter-card__stat{display:flex;justify-content:space-between;gap:12px;font-size:.85rem;color:#475569;font-weight:600}.chapter-card__stat-value{font-weight:800;color:#0f172a}.chapter-card__actions{display:flex;justify-content:flex-end}.chapter-card__btn{padding:8px 16px;border-radius:999px;background:#1e40af;color:#fff;text-decoration:none;font-weight:700;font-size:.9rem;box-shadow:0 10px 18px rgba(30,64,175,.18);transition:transform .2s ease,box-shadow .2s ease,background .2s ease}.chapter-card__btn:hover{background:#1d4ed8;transform:translateY(-1px);box-shadow:0 12px 22px rgba(30,64,175,.24)}.drill-level1-history .learnings-hero{animation:drill-history-panel-in .45s ease}.drill-level1-history .learnings-hero__text,.drill-level1-history .history-trend,.drill-level1-history .history-recent,.drill-level1-history .history-chapters,.drill-level1-history .chapter-card{animation:drill-history-rise .5s ease both}.drill-level1-history .learnings-hero__text{animation-delay:.05s}.drill-level1-history .history-trend{animation-delay:.1s}.drill-level1-history .history-recent{animation-delay:.14s}.drill-level1-history .history-chapters{animation-delay:.18s}.drill-level1-history .chapter-card{animation-delay:.12s}.drill-level1-history .chapter-card:nth-child(2){animation-delay:.16s}.drill-level1-history .chapter-card:nth-child(3){animation-delay:.2s}.drill-level1-history .chapter-card:nth-child(4){animation-delay:.24s}@keyframes drill-history-panel-in{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes drill-history-rise{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}@media(prefers-reduced-motion: reduce){.drill-level1-history .learnings-hero,.drill-level1-history .learnings-hero__text,.drill-level1-history .history-trend,.drill-level1-history .history-recent,.drill-level1-history .history-chapters,.drill-level1-history .chapter-card{animation:none}}
