@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}.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}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}}.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(max-width: 767px){.app-header__container{padding:0 1rem}}@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:60px;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-item{position:relative;display:inline-flex;align-items:center}.app-header__nav-submenu{display:none}.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__nav-link--mobile-only{display:none}.app-header__nav-label--mobile{display:none}.app-header__nav-label--desktop{display:inline}.app-header__nav-link--with-caret{display:inline-flex;align-items:center;gap:8px}.app-header__nav-caret{width:8px;height:8px;border-right:2px solid currentColor;border-bottom:2px solid currentColor;transform:rotate(45deg);margin-bottom:2px}.app-header__nav-dropdown{position:absolute;top:calc(100% + 10px);left:0;min-width:320px;display:none;padding:16px;background:#fff;border-radius:14px;border:1px solid #e2e8f0;box-shadow:0 18px 36px rgba(15,23,42,.18);z-index:1002}.app-header__nav-dropdown::before{content:"";position:absolute;top:-10px;left:0;right:0;height:10px}.app-header__nav-dropdown-group+.app-header__nav-dropdown-group{margin-top:14px;padding-top:12px;border-top:1px solid #eef2f7}.app-header__nav-dropdown-label{font-size:.78rem;font-weight:700;color:#64748b;text-transform:uppercase;letter-spacing:.08em;margin-bottom:8px}.app-header__nav-dropdown-item{display:block;padding:8px 12px;border-radius:10px;color:#0f172a;text-decoration:none;font-weight:600;transition:background-color .2s ease,color .2s ease}.app-header__nav-dropdown-item:hover{background:#eff6ff;color:#1e40af}.app-header__nav-item--study:hover .app-header__nav-dropdown,.app-header__nav-item--study:focus-within .app-header__nav-dropdown{display:block}.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-actions{display:none;flex-direction:column;gap:8px}.app-header__user-action{padding:10px 12px;border-radius:10px;text-align:center;font-weight:700;text-decoration:none;color:#0b1f3a;background:hsla(0,0%,100%,.8);border:1px solid rgba(148,163,184,.3);transition:background-color .2s ease,color .2s ease}.app-header__user-action:hover{background:rgba(226,232,255,.95);color:#0b1f3a}.app-header__user-action--danger{color:#b91c1c;background:rgba(254,242,242,.9);border-color:rgba(248,113,113,.35)}.app-header__user-action--danger:hover{background:rgba(254,226,226,.95);color:#b91c1c}.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{padding:8px 0}.app-header__container{gap:12px}.app-header__logo-text{font-size:1.4rem}.app-header__logo-image{height:42px}.app-header__menu-button{display:inline-flex;margin-left:auto;border-radius:14px;background:rgba(15,23,42,.18);border-color:rgba(191,219,254,.6);box-shadow:0 10px 18px rgba(15,23,42,.28)}.app-header__menu-button span{width:18px;height:2px;box-shadow:none;background:#f8fafc}.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:72px 20px calc(48px + env(safe-area-inset-bottom));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;overflow-y:auto;overscroll-behavior:contain}.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-item{display:block}.app-header__nav-submenu{display:flex;flex-direction:column;gap:8px;max-height:0;opacity:0;transform:translateY(-6px);overflow:hidden;padding:0 10px;margin-top:0;border-radius:12px;background:hsla(0,0%,100%,.7);border:1px solid rgba(0,0,0,0);box-shadow:0 10px 20px rgba(15,23,42,.08);pointer-events:none;transition:max-height .25s ease,opacity .2s ease,transform .25s ease,margin-top .25s ease,padding .25s ease,border-color .25s ease}.app-header__nav-item--study.is-open .app-header__nav-submenu{max-height:520px;opacity:1;transform:translateY(0);padding:8px 10px 6px;margin-top:6px;border-color:rgba(148,163,184,.2);pointer-events:auto}.app-header__nav-submenu-group+.app-header__nav-submenu-group{padding-top:6px;border-top:1px solid rgba(148,163,184,.2)}.app-header__nav-submenu-label{font-size:.65rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:#64748b;margin-bottom:4px}.app-header__nav-submenu-item{display:block;padding:6px 8px;border-radius:10px;color:#0b1f3a;text-decoration:none;font-weight:700;font-size:.92rem;transition:background-color .2s ease,color .2s ease}.app-header__nav-submenu-item:hover{background:rgba(226,232,255,.9);color:#0b1f3a}.app-header__nav-dropdown{display:none !important}.app-header__nav-link--with-caret{gap:6px}.app-header__nav-caret{display:none}.app-header__nav-link{display:flex;align-items:center;padding:10px 12px;font-size:.95rem;color:#0b1f3a;background:hsla(0,0%,100%,.75);border:1px solid rgba(148,163,184,.25);width:100%}.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__nav-link--mobile-only{display:flex}.app-header__nav-label--mobile{display:inline}.app-header__nav-label--desktop{display:none}.app-header__user-email{display:none}.app-header__user-menu{display:none}.app-header__user-actions{display:flex}.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(max-width: 767px){.static-page__container{padding:0 1rem}}@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__category{font-size:.9rem;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.05em;margin-top:24px;padding-bottom:8px;border-bottom:2px solid #1e3a8a}.static-faq__category:first-child{margin-top:0}.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__alert{border:1px solid #fecaca;border-radius:12px;background:#fee2e2;color:#b91c1c;font-weight:600;padding:12px 14px}.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}@media(max-width: 767px){.static-form__input,.static-form__textarea{font-size:16px}}.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(max-width: 767px){.app-footer__container{padding:0 1rem}}@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(220px, 1fr) minmax(360px, 2.2fr);gap:48px}@media(max-width: 767px){.app-footer__content{grid-template-columns:1fr}}.app-footer__brand{display:flex;flex-direction:column;gap:12px;justify-content:flex-end}.app-footer__logo{width:160px;height:auto;display:block}.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(auto-fit, minmax(160px, 1fr));gap:24px 32px;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;text-align:center}.tanto-training-layout{min-height:100vh;display:flex;flex-direction:column}.tanto-training-main{flex:1;background:linear-gradient(135deg, #f8fafc 0%, #e2e8f0 50%, #f1f5f9 100%);padding:2rem 0}.tanto-training-container{max-width:980px;margin:0 auto;padding:0 .25rem}@media(max-width: 767px){.tanto-training-container{padding:0 1rem}}@media(min-width: 1024px){.tanto-training-container{padding:0 .5rem}}.tanto-training-container{max-width:1000px;margin:0 auto}.tanto-header{text-align:center;margin-bottom:2rem}.tanto-header .tanto-title{font-size:2rem;font-weight:700;color:#1f2937;margin-bottom:.5rem;font-family:inherit}.tanto-header .tanto-year{font-size:1.5rem;color:#6b7280;margin-bottom:1.5rem}.tanto-hero{background:linear-gradient(135deg, rgba(255, 255, 255, 0.96) 0%, rgba(239, 246, 255, 0.9) 55%, rgba(255, 255, 255, 0.9) 100%);border:1px solid rgba(148,163,184,.22);border-radius:22px;padding:22px;position:relative;overflow:hidden;margin-bottom:20px;box-shadow:0 18px 34px rgba(15,23,42,.08);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.tanto-hero::before{content:"";position:absolute;top:-42px;right:-140px;width:360px;height:240px;background:linear-gradient(130deg, rgba(29, 78, 216, 0.16), rgba(14, 165, 233, 0.05));transform:skewX(-10deg);border-radius:36px}.tanto-hero::after{content:"";position:absolute;bottom:-140px;left:-80px;width:280px;height:280px;border-radius:999px;background:radial-gradient(circle at 30% 30%, rgba(14, 165, 233, 0.18), rgba(59, 130, 246, 0.02) 65%)}.tanto-hero__inner{display:flex;align-items:flex-start;justify-content:space-between;gap:24px;position:relative;z-index:1}@media(max-width: 767px){.tanto-hero__inner{flex-direction:column;align-items:flex-start}}.tanto-hero__eyebrow{text-transform:uppercase;letter-spacing:.18em;font-size:.75rem;font-weight:700;color:#1d4ed8;margin-bottom:10px}.tanto-hero__title{font-size:2.1rem;font-weight:800;color:#0b1f3a;margin:0 0 10px 0;line-height:1.25;letter-spacing:-0.01em}@media(max-width: 767px){.tanto-hero__title{font-size:1.75rem}}.tanto-hero__subtitle{color:#56657a;font-size:1rem;margin:0 0 14px 0}.tanto-hero__meta{display:flex;flex-wrap:wrap;gap:8px 10px}.tanto-hero__chip{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:999px;border:1px solid rgba(148,163,184,.45);background:hsla(0,0%,100%,.92);color:#0f172a;font-size:.8rem;font-weight:700}.tanto-hero__chip--muted{color:#475569;background:rgba(248,250,252,.92)}.tanto-hero__panel{background:hsla(0,0%,100%,.92);border:1px solid rgba(148,163,184,.24);border-radius:18px;padding:14px 16px;box-shadow:0 16px 26px rgba(15,23,42,.07);min-width:260px;display:flex;flex-direction:column;gap:10px;overflow:hidden;position:relative}.tanto-hero__panel::before{content:"";position:absolute;inset:0;background:linear-gradient(135deg, rgba(29, 78, 216, 0.06), rgba(14, 165, 233, 0.02));pointer-events:none}@media(max-width: 767px){.tanto-hero__panel{width:100%;min-width:0}}.tanto-hero__panel-meta{display:flex;flex-direction:column;gap:6px;position:relative;z-index:1}.tanto-hero__panel-label{font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:#94a3b8;font-weight:800}.tanto-hero__panel-value{font-size:1.1rem;font-weight:900;color:#0b1f3a;white-space:nowrap}.tanto-hero__panel-actions{display:flex;flex-wrap:wrap;gap:10px;justify-content:flex-end;position:relative;z-index:1}.tanto-hero__panel-form{display:inline-flex;margin:0}.tanto-hero__panel-btn{display:inline-flex;align-items:center;justify-content:center;padding:10px 14px;border-radius:999px;border:1px solid #bfdbfe;background:#fff;color:#1e40af;font-weight:800;text-decoration:none;transition:transform .2s ease,background .2s ease,border-color .2s ease,color .2s ease,box-shadow .2s ease;line-height:1;box-shadow:0 10px 18px rgba(15,23,42,.06)}.tanto-hero__panel-btn:hover{background:#eff6ff;transform:translateY(-1px);box-shadow:0 14px 22px rgba(15,23,42,.08)}.tanto-hero__panel-btn:focus-visible{outline:none;box-shadow:0 0 0 3px rgba(29,78,216,.18),0 14px 22px rgba(15,23,42,.08)}.tanto-hero__panel-btn--primary{background:linear-gradient(135deg, #1e40af, #2563eb);border-color:rgba(30,64,175,.6);color:#fff;box-shadow:0 14px 22px rgba(29,78,216,.18)}.tanto-hero__panel-btn--primary:hover{background:linear-gradient(135deg, #1e3a8a, #1d4ed8)}.tanto-hero__panel-btn--muted{border-color:rgba(29,78,216,.28);background:hsla(0,0%,100%,.92);color:#1d4ed8}.tanto-hero__panel-btn--muted:hover{background:rgba(239,246,255,.95);border-color:rgba(29,78,216,.42);color:#1e3a8a}.tanto-hero__panel-btn--muted-strong{border-color:rgba(29,78,216,.32);background:linear-gradient(135deg, rgba(29, 78, 216, 0.14), rgba(14, 165, 233, 0.1));color:#1e3a8a}.tanto-hero__panel-btn--muted-strong:hover{background:linear-gradient(135deg, rgba(29, 78, 216, 0.18), rgba(14, 165, 233, 0.14));border-color:rgba(29,78,216,.45);color:#1e3a8a}.tanto-resume{display:flex;justify-content:center;margin-bottom:1.5rem}.problem-container{background:#fff;border-radius:16px;border:1px solid #e5e7eb;box-shadow:0 4px 6px rgba(0,0,0,.05);margin-bottom:2rem;overflow:hidden}.problem-container .problem-card{padding:2rem}.problem-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.problem-header-left .problem-info{display:flex;align-items:center;gap:.5rem}.problem-header-left .problem-info .problem-year,.problem-header-left .problem-info .problem-number,.problem-header-left .problem-info .problem-law{font-size:1.1rem;font-weight:600;color:#1f2937}.problem-header-left .problem-info .problem-law{color:#2563eb}.problem-header-right .history-table{background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 2px 4px rgba(0,0,0,.05)}.problem-header-right .history-table .history-row{display:flex}.problem-header-right .history-table .history-row:first-child{border-bottom:1px solid #e5e7eb;background:#f8fafc}.problem-header-right .history-table .history-row .history-cell{padding:.375rem .25rem;text-align:center;width:2.5rem;flex:0 0 2.5rem;border-right:1px solid #e5e7eb}.problem-header-right .history-table .history-row .history-cell:last-child{border-right:none}.problem-header-right .history-table .history-row .history-cell .attempt-date{font-size:.7rem;color:#6b7280;font-weight:500}.problem-header-right .history-table .history-row .history-cell .result-mark{font-size:.875rem;font-weight:600}.problem-header-right .history-table .history-row .history-cell .result-mark.correct{color:#059669}.problem-header-right .history-table .history-row .history-cell .result-mark.incorrect{color:#dc2626}.problem-body{line-height:1.7;color:#1f2937;font-size:1rem;margin-bottom:2.5rem;padding:1.5rem;background:#f9fafb;border-radius:8px;border:1px solid #f3f4f6}.problem-body p{margin-bottom:1rem}.problem-body p:last-child{margin-bottom:0}@media(max-width: 767px){.tanto-training-container{padding:0 1rem}.problem-container .problem-card{padding:1.5rem}}.tanto-training-grid{display:grid;grid-template-columns:240px minmax(0, 1fr);gap:24px;align-items:start}.tanto-training-toolbar{display:flex;justify-content:flex-end;align-items:center;gap:12px;margin-bottom:16px}.tanto-training-toolbar__resume{margin-right:auto;box-shadow:0 10px 18px rgba(37,99,235,.18)}.tanto-training-toolbar__actions{display:flex;flex-wrap:wrap;gap:8px}.tanto-training-toolbar .btn{padding:.45rem 1rem;border-radius:999px;font-weight:700;font-size:.85rem;border:1px solid rgba(148,163,184,.7);background:#f8fafc;color:#1f2937;text-decoration:none;display:inline-flex;align-items:center;transition:all .2s ease}.tanto-training-toolbar .btn:hover{background:#eef2ff;border-color:rgba(59,130,246,.35);color:#1e3a8a}.tanto-training-sidebar{background:#fff;border:1px solid #e2e8f0;border-radius:16px;padding:16px;box-shadow:0 12px 20px rgba(15,23,42,.08);position:sticky;--tanto-sticky-top: 104px;top:var(--tanto-sticky-top);margin-top:8px;max-height:calc(100vh - var(--tanto-sticky-top) - 24px);overflow:auto}@media(max-width: 767px){.tanto-training-sidebar{--tanto-sticky-top: 172px}}.tanto-training-sidebar__title{font-size:.9rem;font-weight:700;color:#1e293b;margin-bottom:12px;letter-spacing:.08em;text-transform:uppercase}.tanto-training-sidebar__list{display:flex;flex-direction:column;gap:8px}.tanto-progress-item{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:8px 10px;border-radius:12px;border:1px solid rgba(0,0,0,0);background:#f8fafc;color:#475569;font-weight:700;transition:all .2s ease}.tanto-progress-item__text{font-size:.95rem}.tanto-progress-item__status{min-width:28px;text-align:center;font-size:.9rem;padding:2px 6px;border-radius:999px;background:#e2e8f0;color:#475569}.tanto-progress-item.is-active{border-color:#2563eb;box-shadow:0 10px 16px rgba(37,99,235,.12);background:#eff6ff;color:#1e3a8a}.tanto-progress-item.is-correct .tanto-progress-item__status{background:rgba(34,197,94,.16);color:#166534}.tanto-progress-item.is-incorrect .tanto-progress-item__status{background:rgba(239,68,68,.16);color:#b91c1c}.tanto-progress-item.is-unanswered .tanto-progress-item__status{background:#e2e8f0;color:#94a3b8}.tanto-actions{display:flex;flex-wrap:wrap;gap:12px;justify-content:flex-end;margin-bottom:2rem}.tanto-actions__primary{display:flex;flex-wrap:wrap;gap:12px}.tanto-actions .btn{padding:.75rem 2rem;border-radius:999px;font-weight:700;border:1px solid rgba(0,0,0,0);cursor:pointer;transition:all .2s ease;text-decoration:none;display:inline-flex;align-items:center}.tanto-actions .btn:disabled{opacity:.5;cursor:not-allowed}.tanto-actions .btn.btn-primary{background:linear-gradient(135deg, #3b82f6, #1e40af);color:#fff;border-color:rgba(30,64,175,.2)}.tanto-actions .btn.btn-primary:hover:not(:disabled){background:linear-gradient(135deg, #2563eb, #1e3a8a);transform:translateY(-1px)}.tanto-actions .btn.btn-success{background:linear-gradient(135deg, #10b981, #059669);color:#fff;border-color:rgba(5,150,105,.25)}.tanto-actions .btn.btn-success:hover{background:linear-gradient(135deg, #059669, #047857);transform:translateY(-1px)}.tanto-actions .btn.btn-secondary{background:#f3f4f6;color:#374151;border-color:#d1d5db}.tanto-actions .btn.btn-secondary:hover{background:#e5e7eb}.tanto-actions .btn.btn-small{padding:.4rem .9rem;font-size:.85rem;border-radius:999px}.tanto-actions .btn.btn-ghost{background:#f8fafc;color:#1f2937;border:1px solid rgba(148,163,184,.6)}.tanto-actions .btn.btn-ghost:hover{background:#eef2ff;border-color:rgba(59,130,246,.35);color:#1e3a8a}.choices-train__limit-modal{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;z-index:2000}.choices-train__limit-modal[hidden]{display:none}.choices-train__limit-backdrop{position:absolute;inset:0;background:rgba(15,23,42,.45);animation:choices-result-fade .25s ease}.choices-train__limit-panel{position:relative;width:min(520px,92vw);background:#fff;border-radius:20px;border:1px solid rgba(148,163,184,.35);box-shadow:0 24px 40px rgba(15,23,42,.24);padding:22px 24px;display:flex;flex-direction:column;gap:16px;overflow:hidden;animation:choices-result-rise .5s cubic-bezier(0.16, 1, 0.3, 1)}.choices-train__limit-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.choices-train__limit-title{margin:0;font-size:1.35rem;font-weight:800;color:#1e40af}.choices-train__limit-subtitle{margin:6px 0 0;color:#64748b;font-size:.95rem}.choices-train__limit-close{border:none;background:#e2e8f0;color:#0f172a;font-size:.85rem;font-weight:700;padding:6px 12px;border-radius:999px;cursor:pointer}.choices-train__limit-actions{display:flex;justify-content:flex-end;gap:10px;flex-wrap:wrap}.law-login-modal{position:fixed;inset:0;display:none;align-items:center;justify-content:center;z-index:2100}.law-login-modal.is-visible{display:flex}.law-login-modal__backdrop{position:absolute;inset:0;background:rgba(15,23,42,.55)}.law-login-modal__card{position:relative;width:min(92vw,420px);background:#fff;border-radius:18px;border:1px solid rgba(148,163,184,.3);padding:20px 22px 22px;box-shadow:0 24px 48px rgba(15,23,42,.2);z-index:1}.law-login-modal__header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:8px}.law-login-modal__title{font-size:1.2rem;font-weight:800;color:#0b1f3a}.law-login-modal__close{border:none;background:rgba(0,0,0,0);font-size:1.2rem;color:#64748b;cursor:pointer}.law-login-modal__text{color:#475569;font-size:.95rem;line-height:1.6;margin-bottom:16px}.law-login-modal__actions{display:flex;justify-content:flex-end}.law-login-modal__button{display:inline-flex;align-items:center;justify-content:center;padding:10px 18px;border-radius:999px;background:#1e40af;color:#fff;font-weight:700;text-decoration:none;border:1px solid #1e40af;transition:background .2s ease,transform .2s ease,border-color .2s ease}.law-login-modal__button:hover{background:#1d4ed8;border-color:#1d4ed8;transform:translateY(-1px)}.choices-train__limit-btn{padding:10px 16px;border-radius:999px;border:1px solid #bfdbfe;background:#fff;color:#1e40af;text-decoration:none;font-weight:700;transition:all .2s ease}.choices-train__limit-btn:hover{background:#eff6ff}.choices-train__limit-btn--primary{background:#1e40af;color:#fff;border-color:#1e40af}.tanto-finish-modal{position:fixed;inset:0;z-index:2100;display:flex;align-items:center;justify-content:center;padding:16px}.tanto-finish-modal__backdrop{position:absolute;inset:0;background:rgba(15,23,42,.48);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px)}.tanto-finish-modal__panel{position:relative;width:min(560px,92vw);background:hsla(0,0%,100%,.96);border:1px solid rgba(148,163,184,.28);border-radius:22px;box-shadow:0 28px 54px rgba(15,23,42,.28);padding:22px 22px 18px;overflow:hidden}.tanto-finish-modal__panel::before{content:"";position:absolute;inset:0;background:linear-gradient(135deg, rgba(29, 78, 216, 0.1), rgba(14, 165, 233, 0.04));pointer-events:none}.tanto-finish-modal__header,.tanto-finish-modal__actions{position:relative;z-index:1}.tanto-finish-modal__eyebrow{font-size:.72rem;font-weight:800;letter-spacing:.18em;text-transform:uppercase;color:#1d4ed8;margin-bottom:10px}.tanto-finish-modal__title{margin:0;font-size:1.6rem;font-weight:900;color:#0b1f3a;letter-spacing:-0.01em}.tanto-finish-modal__subtitle{margin:10px 0 0;color:#56657a;font-size:1rem;font-weight:600}.tanto-finish-modal__actions{display:flex;justify-content:flex-end;gap:10px;flex-wrap:wrap;margin-top:18px}.tanto-finish-modal__btn{display:inline-flex;align-items:center;justify-content:center;padding:10px 16px;border-radius:999px;border:1px solid rgba(29,78,216,.32);background:hsla(0,0%,100%,.92);color:#1d4ed8;font-weight:800;text-decoration:none;box-shadow:0 12px 18px rgba(15,23,42,.08);transition:transform .2s ease,background .2s ease,border-color .2s ease,box-shadow .2s ease}.tanto-finish-modal__btn:hover{transform:translateY(-1px);background:rgba(239,246,255,.96);border-color:rgba(29,78,216,.45);box-shadow:0 16px 24px rgba(15,23,42,.1)}.tanto-finish-modal__btn--primary{background:linear-gradient(135deg, #1e40af, #2563eb);border-color:rgba(30,64,175,.6);color:#fff;box-shadow:0 18px 26px rgba(29,78,216,.2)}.tanto-finish-modal__btn--primary:hover{background:linear-gradient(135deg, #1e3a8a, #1d4ed8)}.tanto-result-modal{position:fixed;inset:0;z-index:2050;display:flex;align-items:center;justify-content:center;padding:16px}.tanto-result-modal[hidden]{display:none}.tanto-result-modal__backdrop{position:absolute;inset:0;background:rgba(15,23,42,.46);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px)}.tanto-result-modal__panel{position:relative;width:min(520px,92vw);background:hsla(0,0%,100%,.96);border:1px solid rgba(148,163,184,.28);border-radius:22px;box-shadow:0 26px 50px rgba(15,23,42,.26);padding:20px 20px 16px;overflow:hidden}.tanto-result-modal__panel::before{content:"";position:absolute;inset:0;background:linear-gradient(135deg, rgba(29, 78, 216, 0.1), rgba(14, 165, 233, 0.04));pointer-events:none}.tanto-result-modal.is-correct .tanto-result-modal__panel::before{background:linear-gradient(135deg, rgba(16, 185, 129, 0.14), rgba(29, 78, 216, 0.06))}.tanto-result-modal.is-incorrect .tanto-result-modal__panel::before{background:linear-gradient(135deg, rgba(249, 115, 22, 0.14), rgba(29, 78, 216, 0.06))}.tanto-result-modal__header,.tanto-result-modal__body,.tanto-result-modal__actions{position:relative;z-index:1}.tanto-result-modal__header{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}.tanto-result-modal__title{margin:0;font-size:1.25rem;font-weight:900;color:#0b1f3a;letter-spacing:-0.01em}.tanto-result-modal__close{border:none;background:rgba(226,232,240,.9);color:#0f172a;font-size:.85rem;font-weight:800;padding:6px 12px;border-radius:999px;cursor:pointer;transition:background .2s ease,transform .2s ease}.tanto-result-modal__close:hover{background:rgba(203,213,225,.95);transform:translateY(-1px)}.tanto-result-modal__body{margin-top:14px;text-align:center;font-weight:800;color:#0f172a;line-height:1.6}.tanto-result-modal__body .result-correct{display:inline-block;color:#059669;font-weight:900;font-size:1.3rem;letter-spacing:-0.01em}.tanto-result-modal__body .result-incorrect{display:inline-block;color:#f97316;font-weight:900;font-size:1.3rem;letter-spacing:-0.01em}.tanto-result-modal__actions{display:flex;justify-content:flex-end;gap:10px;flex-wrap:wrap;margin-top:18px}.tanto-result-modal__btn{display:inline-flex;align-items:center;justify-content:center;padding:10px 16px;border-radius:999px;border:1px solid rgba(29,78,216,.32);background:hsla(0,0%,100%,.92);color:#1d4ed8;font-weight:900;text-decoration:none;box-shadow:0 12px 18px rgba(15,23,42,.08);transition:transform .2s ease,background .2s ease,border-color .2s ease,box-shadow .2s ease}.tanto-result-modal__btn:hover{transform:translateY(-1px);background:rgba(239,246,255,.96);border-color:rgba(29,78,216,.45);box-shadow:0 16px 24px rgba(15,23,42,.1)}.tanto-result-modal__btn--primary{background:linear-gradient(135deg, #1e40af, #2563eb);border-color:rgba(30,64,175,.6);color:#fff;box-shadow:0 18px 26px rgba(29,78,216,.2)}.tanto-result-modal__btn--primary:hover{background:linear-gradient(135deg, #1e3a8a, #1d4ed8)}.problem-answer{margin-bottom:2rem}.problem-answer .answer-choices{display:grid;grid-template-columns:repeat(5, minmax(64px, 1fr));gap:.75rem;justify-content:center}.problem-answer .answer-choices .answer-choice{display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;position:relative}.problem-answer .answer-choices .answer-choice:hover{transform:translateY(-2px)}.problem-answer .answer-choices .answer-choice:hover .choice-text{box-shadow:0 4px 12px rgba(59,130,246,.3)}.problem-answer .answer-choices .answer-choice input[type=radio]{position:absolute;opacity:0;cursor:pointer}.problem-answer .answer-choices .answer-choice input[type=radio]:checked+.choice-text{background:linear-gradient(135deg, #3b82f6, #1e40af);color:#fff;box-shadow:0 4px 12px rgba(59,130,246,.4);transform:scale(1.05)}.problem-answer .answer-choices .answer-choice .choice-text{display:inline-block;background:linear-gradient(135deg, #3b82f6, #1e40af);border:2px solid #3b82f6;color:#fff;padding:.75rem 1.25rem;border-radius:999px;font-weight:600;font-size:1.1rem;transition:all .2s ease;min-width:3.5rem;text-align:center;box-shadow:0 4px 12px rgba(59,130,246,.4);width:100%}.problem-answer .answer-choices .answer-choice.correct-answer .choice-text{background:linear-gradient(135deg, #10b981, #059669);border-color:#10b981;color:#fff;box-shadow:0 4px 12px rgba(16,185,129,.4)}.problem-answer .answer-choices .answer-choice.incorrect-answer .choice-text{background:linear-gradient(135deg, #ef4444, #dc2626);border-color:#ef4444;color:#fff;box-shadow:0 4px 12px rgba(239,68,68,.4)}.tanto-result-inline{background:#fff;border:1px solid #e2e8f0;border-radius:16px;padding:20px 22px;margin-bottom:1.5rem;box-shadow:0 4px 6px rgba(0,0,0,.05)}.tanto-result-inline[hidden]{display:none}.tanto-result-inline__header{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}.tanto-result-inline__message{display:flex;align-items:center;gap:10px;font-weight:700;font-size:1.05rem;color:#1e293b}.tanto-result-inline__message .result-correct,.tanto-result-inline__message .result-incorrect{display:inline-flex;align-items:center;justify-content:center;padding:6px 14px;border-radius:8px;font-weight:800;font-size:1rem;background:#1e40af;color:#fff}.tanto-result-inline__message .result-answer{color:#64748b;font-size:.95rem;font-weight:600}.tanto-result-inline__next-btn{padding:10px 20px;border-radius:8px;border:1px solid #1e40af;background:#1e40af;color:#fff;font-weight:700;cursor:pointer;transition:all .2s ease}.tanto-result-inline__next-btn:hover{background:#1d4ed8}.tanto-result-inline__choices{margin-top:18px;padding-top:18px;border-top:1px solid #e2e8f0}.tanto-result-choices__title{font-size:.85rem;font-weight:700;color:#475569;margin-bottom:12px}.tanto-result-choice{display:flex;gap:12px;padding:12px 0;border-bottom:1px solid #f1f5f9}.tanto-result-choice:last-child{border-bottom:none;padding-bottom:0}.tanto-result-choice:first-of-type{padding-top:0}.tanto-result-choice__header{flex-shrink:0;display:flex;align-items:center;gap:8px}.tanto-result-choice__label{font-weight:700;color:#1e40af;font-size:.9rem;min-width:24px}.tanto-result-choice__mark{font-weight:700;font-size:.85rem;width:22px;height:22px;display:flex;align-items:center;justify-content:center;border-radius:50%;border:2px solid #cbd5e1;color:#64748b}.tanto-result-choice.is-correct .tanto-result-choice__mark{border-color:#1e40af;color:#1e40af}.tanto-result-choice__text{color:#334155;font-size:.95rem;line-height:1.6;flex:1}@media(max-width: 767px){.tanto-training-grid{grid-template-columns:1fr}.tanto-training-sidebar{order:2}.tanto-training-work{order:1}.problem-header{flex-direction:column;align-items:flex-start;gap:12px}.answer-choices{grid-template-columns:repeat(3, minmax(64px, 1fr))}.tanto-actions{justify-content:center}.tanto-result-inline{padding:16px}.tanto-result-inline__header{flex-direction:column;align-items:stretch;gap:12px}.tanto-result-inline__next-btn{width:100%;text-align:center;padding:12px 20px}}.app-toast{position:fixed;top:110px;right:18px;width:min(420px,100vw - 32px);padding:14px 16px;border-radius:18px;border:1px solid rgba(148,163,184,.22);box-shadow:0 20px 40px rgba(15,23,42,.16);display:grid;grid-template-columns:minmax(0, 1fr) auto;gap:12px;align-items:center;z-index:2200;opacity:0;transform:translateY(-12px) scale(0.96);pointer-events:none;transition:opacity .28s cubic-bezier(0.4, 0, 0.2, 1),transform .28s cubic-bezier(0.4, 0, 0.2, 1);overflow:hidden}.app-toast::before{content:"";position:absolute;top:-40px;right:-30px;width:100px;height:100px;border-radius:999px;pointer-events:none}.app-toast::after{content:"";position:absolute;bottom:-50px;left:-20px;width:80px;height:80px;border-radius:999px;pointer-events:none}.app-toast.is-visible{opacity:1;transform:translateY(0) scale(1);pointer-events:auto}.app-toast__message{font-weight:700;line-height:1.5;position:relative;z-index:1}.app-toast__close{border:none;width:30px;height:30px;border-radius:999px;cursor:pointer;font-size:16px;line-height:1;display:inline-flex;align-items:center;justify-content:center;transition:transform .2s ease,background .2s ease,box-shadow .2s ease;position:relative;z-index:1}.app-toast__close:hover{transform:scale(1.08)}.app-toast--notice{background:radial-gradient(120px 120px at 95% 10%, rgba(59, 130, 246, 0.22) 0%, transparent 70%),radial-gradient(80px 80px at 5% 90%, rgba(14, 165, 233, 0.18) 0%, transparent 70%),linear-gradient(135deg, rgba(239, 246, 255, 0.98) 0%, rgba(255, 255, 255, 0.98) 100%);border-color:rgba(59,130,246,.25)}.app-toast--notice::before{background:radial-gradient(circle at 50% 50%, rgba(59, 130, 246, 0.12) 0%, transparent 70%)}.app-toast--notice::after{background:radial-gradient(circle at 50% 50%, rgba(14, 165, 233, 0.1) 0%, transparent 70%)}.app-toast--notice .app-toast__message{color:#1e40af}.app-toast--notice .app-toast__close{background:rgba(59,130,246,.12);color:#1e40af}.app-toast--notice .app-toast__close:hover{background:rgba(59,130,246,.22);box-shadow:0 4px 12px rgba(59,130,246,.2)}.app-toast--alert{background:radial-gradient(120px 120px at 95% 10%, rgba(239, 68, 68, 0.18) 0%, transparent 70%),radial-gradient(80px 80px at 5% 90%, rgba(248, 113, 113, 0.14) 0%, transparent 70%),linear-gradient(135deg, rgba(254, 242, 242, 0.98) 0%, rgba(255, 255, 255, 0.98) 100%);border-color:rgba(239,68,68,.22)}.app-toast--alert::before{background:radial-gradient(circle at 50% 50%, rgba(239, 68, 68, 0.1) 0%, transparent 70%)}.app-toast--alert::after{background:radial-gradient(circle at 50% 50%, rgba(248, 113, 113, 0.08) 0%, transparent 70%)}.app-toast--alert .app-toast__message{color:#b91c1c}.app-toast--alert .app-toast__close{background:rgba(239,68,68,.12);color:#b91c1c}.app-toast--alert .app-toast__close:hover{background:rgba(239,68,68,.22);box-shadow:0 4px 12px rgba(239,68,68,.2)}@media(max-width: 767px){.app-toast{top:76px;left:12px;right:12px;width:auto;padding:12px 14px;border-radius:16px}.app-toast__message{font-size:.92rem}.app-toast__close{width:28px;height:28px;font-size:15px}}@media(prefers-reduced-motion: reduce){.app-toast{transition:none}}.tanto-training-container--split{max-width:1200px}.choices-train{display:flex;flex-direction:column;gap:20px}.choices-train__header{display:flex;justify-content:space-between;align-items:flex-end;gap:20px;background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:18px 20px;box-shadow:0 10px 20px rgba(30,64,175,.08)}.choices-train__title{font-size:1.8rem;font-weight:800;color:#1e40af;margin:0 0 6px 0}.choices-train__subtitle{margin:0;color:#64748b;font-size:1rem}.choices-train__meta{display:flex;flex-wrap:wrap;gap:10px 16px;color:#475569;font-size:.95rem;align-items:center}.choices-train__meta strong{color:#1e40af}.choices-train__filter-btn{display:inline-flex;align-items:center;gap:4px;padding:4px 12px;border-radius:999px;border:1px solid #e2e8f0;background:#fff;color:#64748b;font-size:.85rem;font-weight:600;text-decoration:none;transition:all .2s ease}.choices-train__filter-btn:hover{border-color:#f59e0b;color:#f59e0b}.choices-train__filter-btn.is-active{background:#fffbeb;border-color:#f59e0b;color:#d97706}.choices-train__filter-btn svg{display:block;flex-shrink:0}.choices-train__list{display:flex;flex-direction:column;gap:20px;background:#fff;border:1px solid #e2e8f0;border-radius:14px;padding:0;overflow:hidden}.choices-train__pagination{display:flex;justify-content:space-between;gap:12px}.choices-train__page-btn{padding:10px 16px;border-radius:10px;border:1px solid #bfdbfe;background:#fff;color:#1e40af;text-decoration:none;font-weight:700;transition:all .2s ease}.choices-train__page-btn:hover{background:#eff6ff}.choices-train__page-btn--primary{background:#1e40af;color:#fff;border-color:#1e40af}.choices-train__empty{position:relative;padding:48px 32px;background:#fff;border:1px solid #e2e8f0;border-radius:16px;text-align:center;box-shadow:0 16px 28px rgba(30,64,175,.08);overflow:hidden}.choices-train__empty::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 20% 20%, rgba(59, 130, 246, 0.12), rgba(255, 255, 255, 0) 55%),radial-gradient(circle at 85% 10%, rgba(14, 165, 233, 0.1), rgba(255, 255, 255, 0) 45%);pointer-events:none}.choices-train__empty-icon{position:relative;width:64px;height:64px;margin:0 auto 14px;border-radius:16px;background:#eff6ff;color:#1e3a8a;display:inline-flex;align-items:center;justify-content:center;font-size:2rem;font-weight:800;box-shadow:inset 0 0 0 1px rgba(59,130,246,.2)}.choices-train__empty-title{position:relative;margin:0 0 8px;font-size:1.35rem;font-weight:800;color:#0f172a}.choices-train__empty-text{position:relative;margin:0 0 18px;color:#64748b;font-size:.98rem}.choices-train__empty-link{position:relative;display:inline-flex;align-items:center;gap:6px;padding:10px 18px;border-radius:999px;background:#1e40af;color:#fff;font-weight:700;text-decoration:none;border:1px solid #1e40af;transition:transform .2s ease,box-shadow .2s ease,background .2s ease}.choices-train__empty-link:hover{background:#1d4ed8;box-shadow:0 10px 18px rgba(30,64,175,.25);transform:translateY(-1px)}@media(max-width: 768px){.choices-train__empty{padding:36px 20px}.choices-train__empty-icon{width:56px;height:56px;font-size:1.7rem}.choices-train__empty-title{font-size:1.2rem}.choices-train__empty-text{font-size:.92rem}}.choices-train__result-modal{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;z-index:2000}.choices-train__result-modal[hidden]{display:none}.choices-train__result-backdrop{position:absolute;inset:0;background:rgba(15,23,42,.45);animation:choices-result-fade .25s ease}.choices-train__result-panel{position:relative;width:min(640px,92vw);background:#fff;border-radius:20px;border:1px solid rgba(148,163,184,.35);box-shadow:0 24px 40px rgba(15,23,42,.24);padding:22px 24px;display:flex;flex-direction:column;gap:16px;overflow:hidden;animation:choices-result-rise .5s cubic-bezier(0.16, 1, 0.3, 1)}.choices-train__result-panel::before{content:"";position:absolute;inset:0;background:linear-gradient(135deg, rgba(30, 64, 175, 0.08), rgba(14, 165, 233, 0.04));pointer-events:none}.choices-train__result-header{position:relative;display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.choices-train__result-title{margin:0;font-size:1.4rem;font-weight:800;color:#1e40af}.choices-train__result-subtitle{margin:6px 0 0;color:#64748b;font-size:.95rem}.choices-train__result-close{border:none;background:#e2e8f0;color:#0f172a;font-size:.85rem;font-weight:700;padding:6px 12px;border-radius:999px;cursor:pointer}.choices-train__result-stats{position:relative;display:grid;grid-template-columns:repeat(3, minmax(0, 1fr));gap:12px}.choices-train__result-stat{background:hsla(0,0%,100%,.86);border:1px solid rgba(226,232,240,.9);border-radius:14px;padding:12px 14px;display:flex;flex-direction:column;gap:4px;color:#475569;font-size:.85rem;font-weight:600;transform:translateY(8px);opacity:0;animation:choices-result-card .4s ease forwards}.choices-train__result-stat:nth-child(1){animation-delay:.08s}.choices-train__result-stat:nth-child(2){animation-delay:.12s}.choices-train__result-stat:nth-child(3){animation-delay:.16s}.choices-train__result-stat:nth-child(4){animation-delay:.2s}.choices-train__result-stat:nth-child(5){animation-delay:.24s}.choices-train__result-stat strong{font-size:1.35rem;color:#0f172a}.choices-train__result-actions{position:relative;display:flex;justify-content:flex-end;gap:10px;flex-wrap:wrap}.choices-train__result-progress{position:relative;display:flex;flex-direction:column;gap:8px}.choices-train__result-body{display:flex;flex-direction:column;gap:16px}.choices-train__result-actions{margin-top:4px}.choices-train__result-progress-track{position:relative;height:10px;border-radius:999px;background:#fde68a;overflow:hidden;box-shadow:inset 0 1px 2px rgba(15,23,42,.12)}.choices-train__result-progress-base{position:absolute;inset:0 auto 0 0;width:0%;background:linear-gradient(90deg, rgba(251, 146, 60, 0.35), rgba(251, 146, 60, 0.55));transition:width .9s ease}.choices-train__result-progress-gain{position:absolute;inset:0 auto 0 0;width:0%;background:linear-gradient(90deg, #f97316, #fb923c);transition:width .9s ease}.choices-train__result-progress-meta{display:flex;justify-content:space-between;font-size:.85rem;font-weight:700;color:#9a3412}.choices-train__result-progress-meta strong{color:#9a3412}@keyframes choices-result-rise{0%{opacity:0;transform:translateY(18px) scale(0.98) rotate(-2deg)}65%{opacity:1;transform:translateY(-2px) scale(1.01) rotate(0.6deg)}100%{opacity:1;transform:translateY(0) scale(1) rotate(0deg)}}@keyframes choices-result-fade{from{opacity:0}to{opacity:1}}@keyframes choices-result-card{to{transform:translateY(0);opacity:1}}@media(max-width: 520px){.choices-train__result-stats{grid-template-columns:1fr}}@media(max-width: 900px){.choices-train__result-stats{grid-template-columns:repeat(2, minmax(0, 1fr))}}.choices-train__result-btn{padding:10px 16px;border-radius:10px;border:1px solid #c7d2fe;background:#fff;color:#1e40af;text-decoration:none;font-weight:700;transition:all .2s ease}.choices-train__result-btn:hover{background:#eff6ff;transform:translateY(-1px)}.choices-train__result-btn--primary{background:#1e40af;color:#fff;border-color:#1e40af;box-shadow:0 12px 22px rgba(30,64,175,.22)}body.choices-train-modal-open{overflow:hidden}.choice-card{background:#fff;border:1px solid #dbeafe;border-radius:12px;box-shadow:0 14px 28px rgba(30,64,175,.12);padding:18px 20px}.choice-card__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}.choice-card__title{display:flex;align-items:center;gap:10px;font-weight:800;color:#0f172a;font-size:1.1rem}.choice-card__badge{background:#1e40af;color:#fff;padding:4px 10px;border-radius:999px;font-size:.85rem}.choice-card__meta{color:#64748b;font-weight:600}.choice-item{display:grid;grid-template-columns:minmax(0, 1fr) auto;gap:10px 16px;align-items:start;padding:16px 20px;position:relative}.choice-item+.choice-item::before{content:"";position:absolute;top:0;left:20px;right:20px;height:1px;background:#e2e8f0}.choice-item__text{color:#1e293b;font-size:1rem;line-height:1.7;grid-column:1/2;grid-row:2/3}.choice-item__actions{display:flex;gap:8px;flex-wrap:nowrap;align-self:center;grid-column:2/3;grid-row:2/3;justify-self:end}.choice-item__meta{font-size:.9rem;font-weight:700;color:#1e40af;grid-column:1/2;grid-row:1/2;display:flex;align-items:center;gap:6px}.choice-item__law-name{display:inline-block;font-size:.78rem;font-weight:600;color:#475569;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:6px;padding:1px 7px;white-space:nowrap}.choice-item__meta-actions{display:inline-flex;align-items:center;gap:4px;margin-left:auto}.choice-item__bookmark{display:inline-flex;align-items:center;justify-content:center;background:rgba(0,0,0,0);border:none;padding:2px;cursor:pointer;color:#94a3b8;transition:color .2s ease,transform .2s ease;flex-shrink:0}.choice-item__bookmark:hover{color:#f59e0b;transform:scale(1.15)}.choice-item__bookmark.is-active{color:#f59e0b}.choice-item__bookmark.is-active svg{fill:#f59e0b}.choice-item__bookmark svg{display:block}.choice-item__review-flag{display:inline-flex;align-items:center;justify-content:center;background:rgba(0,0,0,0);border:none;padding:2px;cursor:pointer;color:#94a3b8;transition:color .2s ease,transform .2s ease;flex-shrink:0}.choice-item__review-flag:hover{color:#ef4444;transform:scale(1.15)}.choice-item__review-flag.is-active{color:#ef4444}.choice-item__review-flag.is-active svg{fill:#ef4444}.choice-item__review-flag svg{display:block}.choice-item__history{grid-column:2/3;grid-row:1/2;justify-self:end;display:inline-flex;gap:6px;padding:2px 6px;border-radius:999px;background:#f8fafc;color:#475569;font-weight:700;font-size:.8rem;align-items:center;flex-wrap:nowrap;min-height:36px;width:fit-content}.choice-item__history.is-empty{display:none}.choice-item__history-entry{display:grid;justify-items:center;gap:2px;min-width:36px;min-height:36px;padding:4px 6px}.choice-item__history-date{opacity:.75;font-size:.75rem}.choice-item__history-mark{width:20px;height:20px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;font-size:.8rem;border:1px solid #94a3b8}.choice-item__history-mark.incorrect{color:#b91c1c;border-color:#b91c1c}.choice-item.is-correct{box-shadow:inset 4px 0 0 #1e40af}.choice-item.is-incorrect{box-shadow:inset 4px 0 0 #dc2626}.choice-item__feedback{grid-column:1/-1;margin-top:4px;display:inline-flex;align-items:center;justify-self:flex-start;border-radius:999px;padding:4px 10px;font-size:.95rem;font-weight:700;color:#475569;border:1px solid #e2e8f0}.choice-item__feedback:empty{display:none}.choice-item__explanation{grid-column:1/-1;margin-top:10px;padding:12px 14px;border-radius:10px;background:#f8fafc;border:1px solid #e2e8f0;color:#334155}.choice-item__explanation-title{font-size:.9rem;font-weight:700;color:#1e40af;margin-bottom:6px}.choice-item__explanation-body{font-size:.98rem;line-height:1.7}.choice-item__kizyun-ref{grid-column:1/-1;margin-top:4px}.choice-item__kizyun-toggle{display:inline-flex;align-items:center;gap:5px;padding:6px 0;border:none;background:rgba(0,0,0,0);color:#64748b;font-size:.95rem;font-weight:600;cursor:pointer;transition:color .2s ease}.choice-item__kizyun-toggle:hover{color:#1e40af}.choice-item__kizyun-toggle:disabled{opacity:.5;cursor:default}.choice-item__kizyun-chevron{display:inline-block;width:0;height:0;border-left:6px solid currentColor;border-top:5px solid rgba(0,0,0,0);border-bottom:5px solid rgba(0,0,0,0);transition:transform .2s ease}.choice-item__kizyun-ref.is-open .choice-item__kizyun-chevron{transform:rotate(90deg)}.choice-item__kizyun-context{width:100%;margin-top:8px}.choice-item.is-correct .choice-item__feedback{color:#1e40af;border-color:#1e40af}.choice-item.is-incorrect .choice-item__feedback{color:#dc2626;border-color:#dc2626}@media(max-width: 768px){.choice-item{grid-template-columns:1fr;gap:8px}.choice-item__meta,.choice-item__history,.choice-item__text,.choice-item__actions{grid-column:1/-1;grid-row:auto}.choice-item__history{justify-self:flex-start}.choice-item__actions{justify-self:flex-start;align-self:flex-start;display:flex;width:auto;gap:8px}.choice-item__actions .choice-answer__btn{flex:0 0 auto !important;width:44px !important;height:36px;min-width:44px;padding:0;font-size:.85rem;line-height:1;border-radius:10px;text-align:center}}.choice-answer__btn{border:1px solid #bfdbfe;background:#fff;color:#1e40af;padding:8px 14px;border-radius:999px;font-weight:700;cursor:pointer;transition:all .2s ease}.choice-answer__btn:hover{background:#eff6ff}.choice-answer__btn:disabled{opacity:.6;cursor:default}.choice-answer__btn.is-selected:disabled{opacity:1}.choice-answer__btn.is-selected{background:#1e40af;color:#fff;border-color:#1e40af;box-shadow:0 8px 16px rgba(30,64,175,.2)}.problem-container{background:#fff;border-radius:16px;border:1px solid #e5e7eb;box-shadow:0 4px 6px rgba(0,0,0,.05);margin-bottom:2rem;overflow:hidden}.problem-container .problem-card{padding:2rem}.problem-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.problem-header-left .problem-info{display:flex;align-items:center;gap:.5rem}.problem-header-left .problem-info .problem-year,.problem-header-left .problem-info .problem-number{font-size:1.1rem;font-weight:600;color:#1f2937}.problem-header-right .history-table{background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 2px 4px rgba(0,0,0,.05)}.problem-header-right .history-table .history-row{display:flex}.problem-header-right .history-table .history-row:first-child{border-bottom:1px solid #e5e7eb;background:#f8fafc}.problem-header-right .history-table .history-row .history-cell{padding:.375rem .25rem;text-align:center;width:2.5rem;flex:0 0 2.5rem;border-right:1px solid #e5e7eb}.problem-header-right .history-table .history-row .history-cell:last-child{border-right:none}.problem-header-right .history-table .history-row .history-cell .attempt-date{font-size:.7rem;color:#6b7280;font-weight:500}.problem-header-right .history-table .history-row .history-cell .result-mark{font-size:.875rem;font-weight:600}.problem-header-right .history-table .history-row .history-cell .result-mark.correct{color:#059669}.problem-header-right .history-table .history-row .history-cell .result-mark.incorrect{color:#dc2626}.problem-body{line-height:1.7;color:#1f2937;font-size:1rem;margin-bottom:2.5rem;padding:1.5rem;background:#f9fafb;border-radius:8px;border:1px solid #f3f4f6}.problem-body p{margin-bottom:1rem}.problem-body p:last-child{margin-bottom:0}.problem-answer{margin-bottom:2rem}.problem-answer .answer-choices{display:flex;gap:.75rem;justify-content:center;flex-wrap:wrap}.problem-answer .answer-choices .answer-choice{display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;position:relative}.problem-answer .answer-choices .answer-choice:hover{transform:translateY(-2px)}.problem-answer .answer-choices .answer-choice:hover .choice-text{box-shadow:0 4px 12px rgba(59,130,246,.3)}.problem-answer .answer-choices .answer-choice input[type=radio]{position:absolute;opacity:0;cursor:pointer}.problem-answer .answer-choices .answer-choice input[type=radio]:checked+.choice-text{background:linear-gradient(135deg, #3b82f6, #1e40af);color:#fff;box-shadow:0 4px 12px rgba(59,130,246,.4);transform:scale(1.05)}.problem-answer .answer-choices .answer-choice .choice-text{display:inline-block;background:linear-gradient(135deg, #3b82f6, #1e40af);border:2px solid #3b82f6;color:#fff;padding:.75rem 1.25rem;border-radius:8px;font-weight:600;font-size:1.1rem;transition:all .2s ease;min-width:3.5rem;text-align:center;box-shadow:0 4px 12px rgba(59,130,246,.4)}.problem-answer .answer-choices .answer-choice.correct-answer .choice-text{background:linear-gradient(135deg, #10b981, #059669);border-color:#10b981;color:#fff;box-shadow:0 4px 12px rgba(16,185,129,.4)}.problem-answer .answer-choices .answer-choice.incorrect-answer .choice-text{background:linear-gradient(135deg, #ef4444, #dc2626);border-color:#ef4444;color:#fff;box-shadow:0 4px 12px rgba(239,68,68,.4)}.kizyun-context__group{margin-bottom:12px}.kizyun-context__group:last-child{margin-bottom:0}.kizyun-context__group-title{font-size:.85rem;font-weight:700;color:#1e40af;margin-bottom:6px;padding-left:2px}.kizyun-context__viewport{position:relative;overflow:hidden;border-radius:10px;border:1px solid #e2e8f0;background:#fff}.kizyun-context__scroll{max-height:200px;overflow-y:auto;padding:20px 16px}.kizyun-context__fade{position:absolute;left:0;right:0;height:20px;pointer-events:none;z-index:1}.kizyun-context__fade--top{top:0;background:linear-gradient(to bottom, rgb(255, 255, 255) 10px, rgba(255, 255, 255, 0) 20px)}.kizyun-context__fade--bottom{bottom:0;background:linear-gradient(to top, rgb(255, 255, 255) 10px, rgba(255, 255, 255, 0) 20px)}.kizyun-context__item{padding:6px 10px;border-left:3px solid rgba(0,0,0,0);color:#94a3b8;font-size:.92rem;line-height:1.7;transition:all .2s ease}.kizyun-context__item.is-highlighted{border-left-color:#3b82f6;background:#eff6ff;color:#0f172a;border-radius:0 6px 6px 0}
