*,*::before,*::after{box-sizing:border-box}*{margin:0}@media(prefers-reduced-motion: no-preference){html{interpolate-size:allow-keywords}}body{line-height:1.5;-webkit-font-smoothing:antialiased}img,picture,video,canvas,svg{display:block;max-width:100%}input,button,textarea,select{font:inherit}p,h1,h2,h3,h4,h5,h6{overflow-wrap:break-word}p{text-wrap:pretty}h1,h2,h3,h4,h5,h6{text-wrap:balance}#root,#__next{isolation:isolate}ul,ul[role=list],ol[role=list]{list-style:none}a{text-decoration:none}.l-container{width:100%;max-width:1280px;margin-left:auto;margin-right:auto;padding-left:24px;padding-right:24px}@media(min-width: 768px){.l-container{padding-left:40px;padding-right:40px}}.l-container--narrow{max-width:800px}.l-container--wide{max-width:1440px}.l-container--fluid{max-width:100%}.l-container--full{max-width:100%;padding-left:0;padding-right:0}.l-header{width:100%;padding:24px 48px;box-sizing:border-box;display:flex;justify-content:space-between;align-items:center;border-radius:0;border-top:none;border-left:none;border-right:none;z-index:1000;position:sticky;top:0;color:#fff;background:hsla(0,0%,100%,.08);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid hsla(0,0%,100%,.15)}.l-header__brand{display:flex;align-items:center;gap:16px}.l-header__logo-icon{width:32px;height:32px;background:linear-gradient(to bottom right, #3b82f6, #9333ea);border-radius:8px;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px rgba(0,0,0,.3)}.l-header__brand-name{font-size:1.125rem;font-weight:900;font-style:italic;letter-spacing:.1em;color:#fff;text-decoration:none}.l-header__brand-name:hover{opacity:.8}.l-header__nav{display:flex;gap:40px;align-items:center}.l-header__nav-list{display:flex;gap:40px;list-style:none;margin:0;padding:0}.l-header__nav-list li a{font-size:11px;font-weight:bold;letter-spacing:.2em;text-transform:uppercase;color:hsla(0,0%,100%,.6);text-decoration:none;position:relative;transition:all .3s ease;display:flex;align-items:center;gap:8px}.l-header__nav-list li a:hover{color:#fff;text-shadow:0 0 10px hsla(0,0%,100%,.5)}.l-header__nav-list li a::after{content:"";position:absolute;bottom:-4px;left:0;width:0;height:1px;background:#60a5fa;transition:width .3s ease;box-shadow:0 0 8px #60a5fa}.l-header__nav-list li a:hover::after{width:100%}.l-header__nav-link{font-size:11px;font-weight:bold;letter-spacing:.2em;text-transform:uppercase;color:hsla(0,0%,100%,.6);text-decoration:none;position:relative;transition:all .3s ease;display:flex;align-items:center;gap:8px}.l-header__nav-link:hover{color:#fff;text-shadow:0 0 10px hsla(0,0%,100%,.5)}.l-header__nav-link::after{content:"";position:absolute;bottom:-4px;left:0;width:0;height:1px;background:#60a5fa;transition:width .3s ease;box-shadow:0 0 8px #60a5fa}.l-header__nav-link:hover::after{width:100%}.l-header__version{font-size:10px;padding:4px 12px;border:1px solid hsla(0,0%,100%,.15);border-radius:9999px;color:hsla(0,0%,100%,.4);font-weight:bold;letter-spacing:.1em}@media(max-width: 768px){.l-header{padding:20px 24px}.l-header__nav{display:none}}.l-bg-sphere{position:fixed;border-radius:50%;filter:blur(80px);opacity:.3;z-index:-1}.l-bg-sphere--1{width:300px;height:300px;background:#a855f7;top:10%;right:-50px}.l-bg-sphere--2{width:400px;height:400px;background:#60a5fa;bottom:5%;left:-100px}html,body{margin:0;padding:0;background:linear-gradient(135deg, #1e1b4b 0%, #1e3a8a 50%, #581c87 100%);min-height:100vh}#page.site{display:flex;flex-direction:column;min-height:100vh}.l-footer{width:100%;padding:32px 48px;box-sizing:border-box;display:flex;justify-content:space-between;align-items:center;border-radius:0;border-bottom:none;border-left:none;border-right:none;background:hsla(0,0%,100%,.08);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-top:1px solid hsla(0,0%,100%,.15);margin-top:auto}.l-footer__copyright{font-size:10px;color:hsla(0,0%,100%,.4);letter-spacing:.1em;text-transform:uppercase}.l-footer__links{display:flex;gap:32px;align-items:center}.l-footer__link{font-size:10px;font-weight:bold;color:hsla(0,0%,100%,.6);text-decoration:none;text-transform:uppercase;letter-spacing:.1em;transition:color .3s ease}.l-footer__link:hover{color:#60a5fa}.l-footer__nav-list{display:flex;gap:32px;list-style:none;margin:0;padding:0}.l-footer__nav-list li a{font-size:10px;font-weight:bold;color:hsla(0,0%,100%,.6);text-decoration:none;text-transform:uppercase;letter-spacing:.1em;transition:color .3s ease}.l-footer__nav-list li a:hover{color:#60a5fa}@media(max-width: 768px){.l-footer{flex-direction:column;gap:16px;padding:32px 24px}.l-footer__links,.l-footer__nav-list{gap:20px}}.l-grid{display:grid;width:100%;gap:24px;grid-template-columns:1fr}.l-grid--cols-1{grid-template-columns:repeat(1, minmax(0, 1fr))}.l-grid--cols-2{grid-template-columns:repeat(2, minmax(0, 1fr))}.l-grid--cols-3{grid-template-columns:repeat(3, minmax(0, 1fr))}.l-grid--cols-4{grid-template-columns:repeat(4, minmax(0, 1fr))}.l-grid--cols-5{grid-template-columns:repeat(5, minmax(0, 1fr))}.l-grid--cols-6{grid-template-columns:repeat(6, minmax(0, 1fr))}.l-grid--cols-7{grid-template-columns:repeat(7, minmax(0, 1fr))}.l-grid--cols-8{grid-template-columns:repeat(8, minmax(0, 1fr))}.l-grid--cols-9{grid-template-columns:repeat(9, minmax(0, 1fr))}.l-grid--cols-10{grid-template-columns:repeat(10, minmax(0, 1fr))}.l-grid--cols-11{grid-template-columns:repeat(11, minmax(0, 1fr))}.l-grid--cols-12{grid-template-columns:repeat(12, minmax(0, 1fr))}@media(min-width: 768px){.md\:l-grid--cols-1{grid-template-columns:repeat(1, minmax(0, 1fr))}.md\:l-grid--cols-2{grid-template-columns:repeat(2, minmax(0, 1fr))}.md\:l-grid--cols-3{grid-template-columns:repeat(3, minmax(0, 1fr))}.md\:l-grid--cols-4{grid-template-columns:repeat(4, minmax(0, 1fr))}.md\:l-grid--cols-5{grid-template-columns:repeat(5, minmax(0, 1fr))}.md\:l-grid--cols-6{grid-template-columns:repeat(6, minmax(0, 1fr))}.md\:l-grid--cols-7{grid-template-columns:repeat(7, minmax(0, 1fr))}.md\:l-grid--cols-8{grid-template-columns:repeat(8, minmax(0, 1fr))}.md\:l-grid--cols-9{grid-template-columns:repeat(9, minmax(0, 1fr))}.md\:l-grid--cols-10{grid-template-columns:repeat(10, minmax(0, 1fr))}.md\:l-grid--cols-11{grid-template-columns:repeat(11, minmax(0, 1fr))}.md\:l-grid--cols-12{grid-template-columns:repeat(12, minmax(0, 1fr))}}@media(min-width: 1024px){.lg\:l-grid--cols-1{grid-template-columns:repeat(1, minmax(0, 1fr))}.lg\:l-grid--cols-2{grid-template-columns:repeat(2, minmax(0, 1fr))}.lg\:l-grid--cols-3{grid-template-columns:repeat(3, minmax(0, 1fr))}.lg\:l-grid--cols-4{grid-template-columns:repeat(4, minmax(0, 1fr))}.lg\:l-grid--cols-5{grid-template-columns:repeat(5, minmax(0, 1fr))}.lg\:l-grid--cols-6{grid-template-columns:repeat(6, minmax(0, 1fr))}.lg\:l-grid--cols-7{grid-template-columns:repeat(7, minmax(0, 1fr))}.lg\:l-grid--cols-8{grid-template-columns:repeat(8, minmax(0, 1fr))}.lg\:l-grid--cols-9{grid-template-columns:repeat(9, minmax(0, 1fr))}.lg\:l-grid--cols-10{grid-template-columns:repeat(10, minmax(0, 1fr))}.lg\:l-grid--cols-11{grid-template-columns:repeat(11, minmax(0, 1fr))}.lg\:l-grid--cols-12{grid-template-columns:repeat(12, minmax(0, 1fr))}}.l-grid--gap-sm{gap:16px}.l-grid--gap-lg{gap:40px}.l-grid--gap-0{gap:0}:root{--bg:#f4f6fb;--side:#0f172a;--card:#ffffff;--text:#0f172a;--muted:#64748b;--line:#e5e7eb;--primary:#2563eb}.spi-admin{display:flex;min-height:100vh}.spi-side{width:260px;background:linear-gradient(180deg, #0b1224, #0f172a);color:#fff;padding:22px 18px;position:sticky;top:0;height:100vh}.spi-brand{display:flex;gap:12px;align-items:center;padding:10px 10px 18px;border-bottom:1px solid hsla(0,0%,100%,.08);margin-bottom:14px}.spi-brand__logo{width:38px;height:38px;display:grid;place-items:center;border-radius:12px;background:rgba(37,99,235,.25)}.spi-brand__name{font-weight:800;letter-spacing:.2px}.spi-brand__role{font-size:12px;opacity:.7;margin-top:2px}.spi-menu{display:flex;flex-direction:column;gap:8px;margin-top:14px}.spi-menu a{color:#cbd5e1;text-decoration:none;padding:12px 12px;border-radius:10px;display:block;font-weight:600;font-size:14px}.spi-menu a:hover{background:hsla(0,0%,100%,.06)}.spi-menu a.is-active{background:rgba(37,99,235,.25);color:#fff}.spi-logout{margin-top:auto;color:#fecaca !important}.spi-main{flex:1;padding:28px 28px 60px}.spi-topbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}.spi-topbar h1{margin:0;font-size:22px;font-weight:800;color:var(--text)}.spi-userpill{background:#fff;border:1px solid var(--line);padding:8px 12px;border-radius:999px;font-weight:700;font-size:13px;color:#334155}.spi-cards{display:grid;grid-template-columns:repeat(4, minmax(0, 1fr));gap:16px;margin:16px 0 22px}.spi-card{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:18px 18px;box-shadow:0 8px 22px rgba(0,0,0,.05)}.spi-card span{display:block;color:var(--muted);font-weight:700;font-size:12px;margin-bottom:8px}.spi-card strong{font-size:26px;color:var(--text)}.spi-panel{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:18px 18px;box-shadow:0 10px 26px rgba(0,0,0,.05);margin-bottom:18px}.spi-panel__head h2{margin:0;font-size:16px;font-weight:900}.spi-note{margin:6px 0 0;font-size:12px;color:var(--muted)}.spi-grid2{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:18px}.spi-grid3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px;margin-top:14px}.spi-panel__inner{border:1px solid var(--line);border-radius:14px;padding:14px;background:#fff}.spi-panel__inner h3{margin:0 0 8px;font-size:14px;font-weight:900}.spi-radar{height:260px}.spi-radar canvas{width:100% !important;height:260px !important}.spi-cat-grid{display:grid;grid-template-columns:repeat(2, minmax(0, 1fr));gap:14px}.spi-cat-card{display:block;text-decoration:none;border:1px solid var(--line);border-radius:14px;padding:14px;background:#fff;color:inherit}.spi-cat-title{font-weight:900}.spi-cat-rate{font-size:22px;font-weight:900;margin-top:8px}.spi-bar{margin-top:10px;height:8px;background:#eef2ff;border-radius:999px;overflow:hidden}.spi-bar span{display:block;height:8px;background:var(--primary)}.spi-cat-link{margin-top:10px;font-weight:800;color:var(--primary);font-size:13px}.spi-worst-row{display:grid;grid-template-columns:36px 1fr 280px 60px;gap:12px;align-items:center;padding:10px 6px;border-bottom:1px solid #f1f5f9}.spi-rank{width:28px;height:28px;border-radius:999px;display:grid;place-items:center;background:#fee2e2;color:#b91c1c;font-weight:900}.spi-worst-bar{height:8px;background:#e2e8f0;border-radius:999px;overflow:hidden}.spi-worst-bar span{display:block;height:8px;background:#ef4444}.spi-worst-rate{font-weight:900;text-align:right}.spi-report-actions{display:flex;align-items:center;gap:12px;margin:10px 0 14px}.spi-btn{border:none;border-radius:12px;padding:12px 18px;cursor:pointer;font-weight:900}.spi-btn--primary{background:var(--primary);color:#fff}.admin-auth{min-height:100vh;display:grid;place-items:center;background:radial-gradient(ellipse at top, #0b1224, #0f172a);padding:24px}.admin-auth__card{width:min(420px,92vw);border-radius:16px;overflow:hidden;box-shadow:0 18px 50px rgba(0,0,0,.35);border:1px solid hsla(0,0%,100%,.08)}.admin-auth__head{background:hsla(0,0%,100%,.06);padding:26px 26px 18px;text-align:center;color:#fff}.admin-auth__icon{width:52px;height:52px;border-radius:999px;display:grid;place-items:center;margin:0 auto 10px;background:rgba(37,99,235,.5)}.admin-auth__head h1{margin:0;font-size:20px;font-weight:900}.admin-auth__head p{margin:6px 0 0;opacity:.8;font-size:12px}.admin-auth__body{background:#fff;padding:22px 26px}.admin-auth__body label{display:block;font-weight:800;font-size:12px;margin:12px 0 6px;color:#334155}.admin-auth__body input{width:100%;border:1px solid #cbd5e1;border-radius:8px;padding:10px 12px;outline:none}.admin-auth__btn{width:100%;margin-top:16px;padding:12px 12px;border:none;border-radius:10px;background:#0f172a;color:#fff;font-weight:900;cursor:pointer}.admin-auth__error{background:#fee2e2;color:#b91c1c;border:1px solid #fecaca;padding:10px 12px;border-radius:10px;font-weight:800;font-size:13px}.admin-auth__foot{background:#fff;padding:10px 26px 18px;text-align:center;color:#64748b}@media print{.spi-side,.spi-topbar,.spi-report-actions{display:none !important}.spi-main{padding:0}#spiScoreSheet{border:none !important;box-shadow:none !important}}.spi-score-sheet{border:1px solid var(--line);border-radius:16px;padding:18px;background:#fff}.sheet-head{display:flex;justify-content:space-between;align-items:flex-start;padding-bottom:10px;border-bottom:1px solid #f1f5f9}.sheet-title{font-size:18px;font-weight:900}.sheet-meta{font-size:12px;color:#64748b;text-align:right}.sheet-summary{display:grid;grid-template-columns:repeat(3, 1fr);gap:12px;margin:14px 0}.sheet-summary>div{border:1px solid #e5e7eb;border-radius:14px;padding:12px}.sheet-summary span{display:block;font-size:12px;color:#64748b;font-weight:800}.sheet-summary strong{display:block;font-size:22px;font-weight:900;margin-top:6px}.sheet-block h3{margin:14px 0 8px;font-size:14px;font-weight:900}.sheet-row{display:grid;grid-template-columns:30px 1fr 260px 60px;gap:10px;align-items:center;padding:8px 0;border-bottom:1px solid #f1f5f9}.sheet-rank{width:24px;height:24px;border-radius:999px;display:grid;place-items:center;background:#fee2e2;color:#b91c1c;font-weight:900;font-size:12px}.sheet-bar{height:8px;background:#e2e8f0;border-radius:999px;overflow:hidden}.sheet-bar span{display:block;height:8px;background:#ef4444}.sheet-rate{font-weight:900;text-align:right}.sheet-foot{margin-top:10px;color:#64748b}.l-login-wrapper{min-height:100vh;display:flex;align-items:center;justify-content:center;margin:0;background:linear-gradient(135deg, #312e81 0%, #1e3a8a 50%, #581c87 100%);font-family:"Helvetica Neue",Arial,"Hiragino Kaku Gothic ProN","Hiragino Sans",Meiryo,sans-serif}.p-exam-card{display:block;padding:24px;border:1px solid #e2e8f0;border-radius:.5rem;background-color:#fff;text-decoration:none}.p-exam-card{transition:all .3s ease-in-out}.p-exam-card:hover{transform:translateY(-2px);box-shadow:0 10px 25px rgba(0,0,0,.05);border-color:#1658a0}.p-exam-card__title{font-size:1.125rem;font-weight:700;color:#0f172a;margin-bottom:8px}.p-exam-card__text{font-size:.875rem;color:#64748b;line-height:1.6}.c-card--glass{background:hsla(0,0%,100%,.15);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid hsla(0,0%,100%,.3);border-radius:1rem;padding:40px;width:100%;max-width:400px;box-shadow:0 25px 50px -12px rgba(51,51,51,.5);margin:0 auto}.c-input--glass{width:100%;padding:16px 24px;background:hsla(0,0%,100%,.1);border:1px solid hsla(0,0%,100%,.2);border-radius:.75rem;color:#fff;font-size:1rem;outline:none;transition:.3s ease-in-out;box-sizing:border-box}.c-input--glass::placeholder{color:hsla(0,0%,100%,.6)}.c-input--glass:focus{background:hsla(0,0%,100%,.2);border-color:hsla(0,0%,100%,.5)}.c-btn--gradient{width:100%;padding:16px;background:linear-gradient(to right, #3b82f6, #8b5cf6);border:none;border-radius:.75rem;color:#fff;font-weight:700;font-size:1.125rem;cursor:pointer;transition:.3s ease-in-out;box-shadow:0 10px 15px -3px rgba(59,130,246,.3)}.c-btn--gradient:hover{transform:translateY(-2px);box-shadow:0 20px 25px -5px rgba(59,130,246,.4)}.c-btn--gradient:active{transform:translateY(0)}.c-btn--glass{display:inline-flex;align-items:center;justify-content:center;padding:12px 24px;background:hsla(0,0%,100%,.15);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid hsla(0,0%,100%,.3);border-radius:.75rem;color:#fff;font-weight:700;font-size:1rem;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 6px -1px rgba(51,51,51,.1);text-decoration:none}.c-btn--glass:hover{background:hsla(0,0%,100%,.25);transform:translateY(-2px);box-shadow:0 10px 15px -3px rgba(51,51,51,.2)}.c-btn--glass:active{transform:translateY(0)}.c-media-popup{position:fixed;top:0;left:0;width:100vw;height:100vh;z-index:9999;display:flex;justify-content:center;align-items:center;padding:20px;box-sizing:border-box}.c-media-popup__bg{position:absolute;top:0;left:0;width:100%;height:100%;background-color:rgba(0,0,0,.8);cursor:pointer}.c-media-popup__content{position:relative;max-width:90vw;max-height:90vh;background:#fff;border-radius:8px;box-shadow:0 10px 40px rgba(0,0,0,.5);overflow:hidden;display:flex;flex-direction:column}.c-media-popup__close{position:absolute;top:10px;right:10px;width:40px;height:40px;background:rgba(0,0,0,.5);color:#fff;border:none;border-radius:50%;font-size:24px;display:flex;justify-content:center;align-items:center;cursor:pointer;z-index:2;transition:background .2s}.c-media-popup__close:hover{background:rgba(0,0,0,.8)}#media-popup-container{width:100%;height:100%;max-height:90vh;overflow:auto;display:flex;justify-content:center;align-items:center;background:#f0f0f0}#media-popup-container img{max-width:100%;height:auto;display:block}#media-popup-container iframe{width:80vw;height:80vh;border:none;display:block}.c-media-enlarge-btn{display:inline-flex;align-items:center;justify-content:center;margin-top:8px;margin-bottom:16px;padding:6px 12px;background:#f1f5f9;color:#2563eb;border:1px solid #cbd5e1;border-radius:4px;font-size:13px;font-weight:bold;cursor:pointer;transition:all .2s ease;text-decoration:none}.c-media-enlarge-btn:hover{background:#e2e8f0;color:#1d4ed8}.c-media-popup__controls{position:absolute;bottom:20px;left:50%;transform:translateX(-50%);display:flex;align-items:center;gap:15px;background:rgba(0,0,0,.7);padding:10px 20px;border-radius:30px;color:#fff;font-weight:bold;z-index:10;box-shadow:0 4px 15px rgba(0,0,0,.3)}.c-media-zoom-btn{background:rgba(0,0,0,0);border:none;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:5px;border-radius:50%;transition:background .2s}.c-media-zoom-btn:hover{background:hsla(0,0%,100%,.2)}.c-media-popup__loader{position:absolute;top:50%;left:50%;transform:translate(-50%, -50%);background:rgba(0,0,0,.7);color:#fff;padding:15px 30px;border-radius:8px;font-size:14px;font-weight:bold;display:flex;align-items:center;gap:10px;z-index:5}.c-media-popup__loader::before{content:"";display:block;width:20px;height:20px;border:3px solid hsla(0,0%,100%,.3);border-top-color:#fff;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.p-home{padding:64px 0}.p-home__header{text-align:center;margin-bottom:48px}.p-home__title{font-family:"Inter","Noto Sans JP",sans-serif;font-size:1.875rem;font-weight:700;color:#0f172a;margin-bottom:16px}.p-home__lead{font-size:1rem;color:#64748b}.p-home__exam-list{display:grid;grid-template-columns:1fr;gap:24px}@media(min-width: 768px){.p-home__exam-list{grid-template-columns:repeat(3, 1fr)}}.l-page-wrapper{min-height:80vh;display:flex;flex-direction:column;position:relative;padding:60px 20px;z-index:1}.p-category-header{text-align:center;margin-bottom:50px;animation:fadeInDown .6s ease-out}.p-category-header__label{display:inline-block;font-size:.75rem;font-weight:900;color:#60a5fa;text-transform:uppercase;letter-spacing:.2em;margin-bottom:12px}.p-category-header__title{font-size:2.25rem;font-weight:900;color:#fff;letter-spacing:-0.01em}@media(max-width: 640px){.p-category-header__title{font-size:1.75rem}}.c-category-grid{display:grid;grid-template-columns:repeat(auto-fill, minmax(320px, 1fr));gap:24px;max-width:1100px;margin:0 auto;width:100%}@media(max-width: 640px){.c-category-grid{grid-template-columns:1fr}}.c-category-card{display:flex;justify-content:space-between;align-items:center;padding:30px;text-decoration:none;transition:all .3s cubic-bezier(0.4, 0, 0.2, 1);position:relative;overflow:hidden}.c-category-card:hover{transform:scale(1.02);background:hsla(0,0%,100%,.08);border-color:rgba(96,165,250,.4);box-shadow:0 15px 35px rgba(51,51,51,.4)}.c-category-card__body h3{font-size:1.25rem;font-weight:900;color:#fff;margin-bottom:8px;transition:color .3s}.c-category-card__body p{font-size:.875rem;color:hsla(0,0%,100%,.5);line-height:1.5;margin:0}.c-category-card:hover .c-category-card__body h3{color:#60a5fa}.c-category-card__arrow{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:hsla(0,0%,100%,.05);border-radius:50%;color:#fff;font-size:1.25rem;transition:all .3s;flex-shrink:0}.c-category-card:hover .c-category-card__arrow{background:#60a5fa;color:#fff;transform:translateX(5px);box-shadow:0 0 15px rgba(96,165,250,.5)}@media(max-width: 640px){.c-category-card{padding:24px}}.l-quiz-wrap{min-height:100vh;display:flex;flex-direction:column;background-color:#f0f2f5;color:#333;font-family:"Helvetica Neue",Arial,"Hiragino Kaku Gothic ProN","Hiragino Sans",Meiryo,sans-serif;margin:0}.l-quiz-container{flex:1;display:flex;flex-direction:column;align-items:center;padding:30px 20px}.l-quiz-grid{display:grid;grid-template-columns:1.2fr 1fr;flex:1}@media(max-width: 850px){.l-quiz-grid{grid-template-columns:1fr}}.p-quiz-header{background-color:#004bb1;color:#fff;padding:12px 30px;display:flex;justify-content:space-between;align-items:center;box-shadow:0 2px 4px rgba(51,51,51,.1);z-index:100}.p-header-left .p-quiz-breadcrumb{font-size:13px;font-weight:bold;opacity:.9;margin-bottom:2px}.p-header-left .p-timer-text-wrap{display:flex;align-items:baseline;gap:10px}.p-header-left .p-timer-text-wrap .p-timer-label{font-size:10px;opacity:.7;font-weight:bold;text-transform:uppercase}.p-header-left .p-timer-text-wrap #totalTimer{font-size:24px;font-weight:bold;font-family:monospace}.p-header-right .p-ring-area{display:flex;align-items:center}.p-quiz-card{background-color:#fff;border:1px solid #d1d5db;width:100%;max-width:1100px;min-height:600px;box-shadow:0 4px 12px rgba(51,51,51,.05);display:flex;flex-direction:column}.p-question-header{background-color:#f9fafb;border-bottom:1px solid #d1d5db;padding:15px 30px;display:flex;justify-content:space-between;align-items:center}.p-question-header h2{font-size:18px;margin:0;color:#004bb1;display:flex;align-items:baseline}.p-question-content{padding:40px;border-right:1px solid #d1d5db}@media(max-width: 850px){.p-question-content{border-right:none;border-bottom:1px solid #d1d5db}}.p-answer-content{padding:40px}.p-question-text{font-size:16px;line-height:1.8;margin-bottom:30px}.p-question-images img{max-width:100%;height:auto;border:1px solid #eee;margin-bottom:20px}.p-question-choices{list-style:none;padding:0;margin:0}.p-question-choices li{margin-bottom:12px}.p-question-choices label{display:flex;align-items:center;padding:18px 24px;border:1px solid #d1d5db;border-radius:4px;cursor:pointer;background-color:#f9fafb;transition:all .2s}.p-question-choices label:hover{background-color:#eff6ff;border-color:#004bb1}.p-question-choices label input[type=radio],.p-question-choices label input[type=checkbox]{margin-right:15px;width:18px;height:18px;accent-color:#004bb1}.p-quiz-footer{padding:20px 30px;border-top:1px solid #d1d5db;display:flex;justify-content:flex-end}.p-answer-input{width:100%;padding:15px 20px;font-size:16px;border:1px solid #d1d5db;border-radius:4px;outline:none;background-color:#fff;color:#333}.p-answer-input:focus{border-color:#004bb1}.c-btn--spi-next{background-color:#004bb1;color:#fff;border:none;padding:14px 50px;font-size:16px;font-weight:bold;border-radius:4px;cursor:pointer;transition:background-color .2s}.c-btn--spi-next:hover{opacity:.9}.c-time-blocks{display:flex;gap:3px;margin-top:40px}.c-time-blocks span{flex:1;height:5px;background:#e5e7eb;border-radius:1px}.c-time-blocks span.is-active{background:#004bb1}.c-double-ring{position:relative;width:76px;height:76px;--ans-color: #ffd700;--time-color: #ffffff}.c-donut{position:absolute;inset:0;border-radius:50%;--p: 0;--c: #fff;transition:all .5s cubic-bezier(0.4, 0, 0.2, 1)}.c-donut--time{background:conic-gradient(var(--time-color) calc(var(--p) * 1%), transparent 0);-webkit-mask:radial-gradient(farthest-side, transparent 85%, #ffffff 87%);border:1px solid hsla(0,0%,100%,.1);box-sizing:border-box}.c-donut--ans{inset:11px;background:conic-gradient(var(--ans-color) calc(var(--p) * 1%), transparent 0);-webkit-mask:radial-gradient(farthest-side, transparent 80%, #ffffff 82%);border:1px solid hsla(0,0%,100%,.1);box-sizing:border-box}.c-trace-dot{position:absolute;width:8px;height:8px;background:var(--c);border-radius:50%;top:-4px;left:calc(50% - 4px);z-index:10;box-shadow:0 0 10px var(--c);pointer-events:none;transition:transform .5s cubic-bezier(0.4, 0, 0.2, 1)}.c-trace-dot--time{--c: var(--time-color);transform-origin:4px 42px}.c-trace-dot--ans{--c: var(--ans-color);transform-origin:4px 31px}.c-ring-center{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;font-size:8px;color:hsla(0,0%,100%,.7);font-weight:bold}.c-ring-center #ansText{font-size:11px;color:#fff}.quiz-result{max-width:900px;margin:40px auto;padding-bottom:80px}.quiz-result h1{font-size:28px;font-weight:700;margin-bottom:24px;color:#fff}.quiz-result h2{font-size:22px;margin:48px 0 20px;border-left:6px solid #2563eb;padding-left:12px;color:#fff}.spi-score-sheet{box-shadow:10px 10px 15px rgba(0,0,0,.42)}.spi-score-sheet h2{color:#333;text-align:left}.result-summary{display:grid;grid-template-columns:repeat(auto-fit, minmax(180px, 1fr));gap:16px;background:#f8fafc;border:1px solid #e5e7eb;border-radius:14px;padding:20px 24px}.result-summary p{margin:0;font-size:16px}.result-summary strong{font-size:20px;color:#111827}.result-actions{margin-top:24px;text-align:center}.result-actions .c-btn{font-size:16px;padding:12px 28px;border-radius:999px}.result-card{margin-top:24px;border-radius:16px;padding:20px 24px;border:2px solid rgba(0,0,0,0);background:#fff;box-shadow:10px 10px 15px rgba(0,0,0,.42)}.result-card.is-correct{border-color:#22c55e;background:#f0fdf4}.result-card.is-wrong{border-color:#ef4444;background:#fef2f2}.result-card.is-timeout{border-color:#f59e0b;background:#fffbeb}.result-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.result-head strong{font-size:18px}.result-status{font-weight:700;font-size:14px}.is-correct .result-status{color:#16a34a}.is-wrong .result-status{color:#dc2626}.is-timeout .result-status{color:#d97706}.result-question{font-size:16px;line-height:1.8;margin-bottom:16px}.result-answers{background:#f9fafb;border:1px dashed #d1d5db;border-radius:12px;padding:12px 16px;margin-bottom:16px}.result-answers p{margin:6px 0;font-size:15px}.result-answers strong{color:#111827}.result-choices{list-style:none;padding:0;margin:0 0 16px}.result-choices li{display:flex;gap:8px;align-items:flex-start;padding:10px 14px;border-radius:10px;margin-bottom:8px;background:#f9fafb;border:1px solid #e5e7eb;font-size:15px}.result-choices li.is-correct-choice{background:#dcfce7;border-color:#22c55e;font-weight:600}.result-choices li.is-user-choice{background:#fee2e2;border-color:#ef4444}.result-choices li.is-user-correct-choice{background:#bbf7d0;border-color:#16a34a;font-weight:700}.explain-toggle{background:#2563eb;color:#fff;border:none;border-radius:999px;padding:8px 20px;font-size:14px;cursor:pointer}.explain-toggle:hover{opacity:.9}.explain-body{display:none;margin-top:12px;padding:16px;background:#f1f5f9;border-radius:12px;font-size:15px;line-height:1.7}.explain-body.is-open{display:block}@media(max-width: 640px){.quiz-result{padding:0 16px 80px}.result-head{flex-direction:column;align-items:flex-start;gap:4px}.result-summary{grid-template-columns:1fr}}.score-grid strong{display:block}#levelChart{background:#fff;padding:20px;border-radius:1rem}.weak-grid canvas{background:#fff;padding:10px;border-radius:.75rem}.p-login{position:relative;overflow:hidden;z-index:10}.p-login__title{color:#fff;font-size:28px;font-weight:900;text-align:center;margin-bottom:40px;text-shadow:0 2px 4px rgba(51,51,51,.3)}.p-login__error{color:#ffb3b3;margin-bottom:16px;text-align:center;font-weight:700}.p-login__form-group{margin-bottom:24px}.p-login__sphere{position:absolute;border-radius:9999px;filter:blur(60px);opacity:.4;z-index:-1}.p-login__sphere--1{width:200px;height:200px;background:#c084fc;top:-50px;right:-50px}.p-login__sphere--2{width:200px;height:200px;background:#60a5fa;bottom:-50px;left:-50px}.l-home-wrapper{min-height:80vh;display:flex;flex-direction:column;position:relative;padding:60px 20px;z-index:1}.p-home__header{text-align:center;margin-bottom:60px;animation:fadeInDown .8s ease-out}.p-home__title{font-size:2.5rem;font-weight:900;color:#fff;margin-bottom:16px;letter-spacing:-0.02em;text-shadow:0 2px 10px rgba(51,51,51,.2)}@media(max-width: 768px){.p-home__title{font-size:1.8rem}}.p-home__lead{font-size:1.125rem;color:hsla(0,0%,100%,.7);max-width:600px;margin:0 auto}.p-home__exam-list{display:grid;gap:30px;max-width:1200px;margin:0 auto;width:100%}@media(max-width: 768px){.p-home__exam-list{grid-template-columns:1fr}}.p-exam-card{display:flex;flex-direction:column;padding:40px;text-decoration:none;transition:all .4s cubic-bezier(0.175, 0.885, 0.32, 1.275);height:100%}.p-exam-card:hover{transform:translateY(-10px);background:hsla(0,0%,100%,.1);border-color:rgba(96,165,250,.5);box-shadow:0 20px 40px rgba(51,51,51,.3)}.p-exam-card__title{font-size:1.5rem;font-weight:900;color:#fff;margin-bottom:16px;position:relative;padding-bottom:12px}.p-exam-card__title::after{content:"";position:absolute;bottom:0;left:0;width:40px;height:3px;background:linear-gradient(to right, #3b82f6, #8b5cf6);border-radius:2px}.p-exam-card__text{font-size:.95rem;line-height:1.6;color:hsla(0,0%,100%,.6)}@keyframes fadeInDown{from{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.l-setting-wrapper{min-height:90vh;display:flex;flex-direction:column;position:relative;padding:60px 20px;z-index:1}.p-setting-card{max-width:700px;margin:0 auto;padding:50px;box-shadow:0 25px 50px -12px rgba(51,51,51,.5);animation:fadeInUp .8s ease-out}@media(max-width: 640px){.p-setting-card{padding:30px 20px}}.p-setting-title{font-size:2rem;font-weight:900;color:#fff;text-align:center;margin-bottom:40px;letter-spacing:-0.02em}.p-setting-section-title{font-size:.85rem;font-weight:900;color:#60a5fa;text-transform:uppercase;letter-spacing:.2em;margin-bottom:20px;display:flex;align-items:center;gap:10px}.p-setting-section-title::after{content:"";flex:1;height:1px;background:hsla(0,0%,100%,.1)}.c-detail-tags{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:40px}.c-tag{padding:12px 24px;border-radius:16px;border:1px solid hsla(0,0%,100%,.1);background:hsla(0,0%,100%,.05);color:hsla(0,0%,100%,.6);cursor:pointer;font-size:.9rem;font-weight:500;transition:all .3s ease;outline:none}.c-tag:hover{background:hsla(0,0%,100%,.1);color:#fff;border-color:hsla(0,0%,100%,.3)}.c-tag.is-active{background:linear-gradient(135deg, #3b82f6, #8b5cf6);color:#fff;border-color:rgba(0,0,0,0);box-shadow:0 10px 20px rgba(59,130,246,.3)}.p-setting-select-wrapper{margin-bottom:40px;position:relative}.c-select--glass{width:100%;padding:16px 24px;background:hsla(0,0%,100%,.05);border:1px solid hsla(0,0%,100%,.1);border-radius:16px;color:#fff;font-size:1.125rem;font-weight:700;appearance:none;cursor:pointer;outline:none;transition:all .3s;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right 20px center;background-size:16px}.c-select--glass:focus{border-color:#60a5fa;background:hsla(0,0%,100%,.1)}.c-select--glass option{background:#0f172a;color:#fff}.p-time-box{background:rgba(51,51,51,.2);border-radius:20px;padding:30px;text-align:center;margin-bottom:40px;border:1px dashed hsla(0,0%,100%,.1)}.p-time-label{font-size:.75rem;color:hsla(0,0%,100%,.4);text-transform:uppercase;letter-spacing:.1em;margin-bottom:8px}#timePreview{font-size:2.5rem;font-weight:900;color:#fff;letter-spacing:-0.02em}@media(max-width: 640px){#timePreview{font-size:1.75rem}}.p-btn--submit{width:100%;padding:20px;background:linear-gradient(to right, #3b82f6, #8b5cf6);border:none;border-radius:20px;color:#fff;font-size:1.25rem;font-weight:900;cursor:pointer;transition:all .4s cubic-bezier(0.175, 0.885, 0.32, 1.275);box-shadow:0 15px 30px rgba(59,130,246,.4)}.p-btn--submit:hover{transform:translateY(-5px);filter:brightness(1.1);box-shadow:0 20px 40px rgba(59,130,246,.5)}@keyframes fadeInUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.u-animate-fade{animation:fadeIn .8s ease-out forwards}
