*,*:before,*:after{box-sizing:border-box}html{-webkit-text-size-adjust:100%;text-size-adjust:100%}body,h1,h2,h3,h4,h5,h6,p,ul,ol,dl,dd,figure,blockquote{margin:0}ul,ol{padding:0;list-style:none}img,picture{display:block;max-width:100%}table{border-collapse:collapse;border-spacing:0}input,button,textarea,select{font:inherit;color:inherit}button,input[type=button],input[type=submit],input[type=reset]{appearance:none;-webkit-appearance:none;background:none;border:0;padding:0;cursor:pointer}input:not([type=checkbox]):not([type=radio]):not([type=range]):not([type=file]),textarea,select{appearance:none;-webkit-appearance:none;width:100%;background:transparent;margin:0;border-radius:4px}textarea{resize:vertical}a{color:inherit;text-decoration:none}body{font-family:"M PLUS 2",sans-serif;color:#2b3140;background:#f7f8fc;line-height:1.4;font-size:13px}section.section-wrapper{margin-bottom:40px}.app-shell{min-height:100vh}.app-header{position:sticky;top:0;z-index:20;background:#ffffffe6;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid #e7ebf4}.app-header__inner{position:relative;display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:20px;max-width:1280px;min-height:60px;margin:0 auto;padding:16px 24px}.app-brand__logo{font-family:"M PLUS 2",sans-serif;font-size:18px;font-weight:700;color:#2b3140;letter-spacing:.01em}.app-nav{display:flex;gap:10px;align-items:center;justify-content:center;flex-wrap:wrap}.app-nav__link{display:inline-flex;align-items:center;justify-content:center;padding:8px 12px;border-radius:999px;color:#6d7485;font-size:14px;font-weight:600;transition:all .2s ease}.app-nav__link:hover{background:#f3f5fb;color:#2b3140}.app-user{display:flex;align-items:center;gap:12px}.app-user__meta{display:grid;justify-items:end;line-height:1.2}.app-user__name{font-size:14px;font-weight:700;color:#2b3140}.app-user__role{font-size:12px;color:#6d7485}.app-user__logout{margin:0}@media(max-width:900px){.app-header__inner{grid-template-columns:1fr;justify-items:stretch}.app-brand{text-align:center}.app-nav,.app-user{justify-content:center}.app-user__meta{justify-items:center}}.app-menu-toggle{display:none;width:44px;height:44px;padding:0;background:#fff;align-items:center;justify-content:center;cursor:pointer;position:relative;border:none}.app-menu-toggle__icon{width:36px;height:36px;object-fit:contain;display:block}.app-menu-toggle__icon--close,.app-header.is-menu-open .app-menu-toggle__icon--open{display:none}.app-header.is-menu-open .app-menu-toggle__icon--close{display:block}.header-button{display:inline-flex;align-items:center;justify-content:center;padding:8px 12px;border-radius:8px;font-size:12px;font-weight:700;transition:background-color .2s ease,transform .2s ease}.header-button-logout{background-color:#fbf0f2;color:#8a5961;border:2px solid #c79098}.header-button:hover{opacity:.8}@media(max-width:768px){.app-menu-toggle{display:inline-flex;position:absolute;right:10px;top:8px}.app-nav,.app-user{display:none}.app-header.is-menu-open .app-nav,.app-header.is-menu-open .app-user{display:flex}}.app-main{padding:32px 0 48px}.app-container{max-width:1280px;margin:0 auto;padding:0 24px}.page-eyebrow{margin:0;font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#6d7485}.page-header{margin-bottom:8px}.page-header-actions{margin-top:8px}.page-title{margin:0 0 4px;font-family:"M PLUS 2",sans-serif;font-size:28px;font-weight:700;color:#2b3140}.page-subtitle{color:#6d7485;font-size:12px;margin:0 0 8px}@media(max-width:640px){.app-main{padding:24px 0 36px}.app-container{padding:0 16px}.page-header{flex-direction:column;align-items:stretch}}.flash-message{margin-bottom:16px;padding:14px 16px;border:1px solid transparent;border-radius:14px;box-shadow:#00000005 0 1px 3px,#1b1f2326 0 0 0 1px;font-size:14px}.flash-message--success{background:#edf7f5;border-color:#cfe7df;color:#4e7e74}.flash-message--error{background:#fff3f4;border-color:#f0d5da;color:#9a5d6b}.flash-message__list{margin:0;padding-left:20px}.table-panel{background:#fff;border-radius:8px;box-shadow:#00000005 0 1px 3px,#1b1f2326 0 0 0 1px;padding:20px}.table-panel-header{margin-bottom:14px}.table-panel-title{font-size:16px;font-weight:700;color:#2b3140}.link-button{display:inline-flex;align-items:center;justify-content:center;padding:8px 12px;border-radius:8px;font-size:12px;font-weight:700;transition:background-color .2s ease,transform .2s ease}.link-button-primary{background-color:#eef2fb;color:#4f6299;border:2px solid #7b8fc7}.link-button-register{background-color:#faf6e9;color:#8a7440;border:2px solid #8a7440}.link-button-edit{background-color:#edf7f5;color:#587f79;border:2px solid #587f79}.link-button-cancel{background-color:#fbf0f2;color:#8a5961;border:2px solid #c79098}.link-button:hover{opacity:.8}.pagination-nav{display:flex;justify-content:center;margin-top:24px}.table-wrap{overflow-y:scroll}.base-table{width:100%}.base-table th,.base-table td{word-break:keep-all;white-space:nowrap;text-align:center}.base-table th{background:#f3f5fb;color:#6d7485;font-size:10px;font-weight:700;letter-spacing:.02em;padding:12px}.base-table td{font-size:12px;padding:8px;border-bottom:1px solid #f3f5fb}.base-table tbody tr:hover td{background:#fafbfe}.table-actions{display:flex;gap:8px;align-items:center;justify-content:center;flex-wrap:nowrap}.table-button{display:inline-flex;align-items:center;justify-content:center;padding:8px 12px;border-radius:8px;background:#f4effb;color:#6f5b98;font-size:12px;font-weight:700;transition:background-color .2s ease}.table-button-detail{background-color:#eef2fb;color:#4f6299;border:2px solid #7b8fc7}.table-button-edit{background-color:#edf7f5;color:#587f79;border:2px solid #8eb7b0}.table-button-register,.table-button-accent{background-color:#faf6e9;color:#8a7440;border:2px solid #d8c27a}.table-button-danger{background-color:#fbf0f2;color:#8a5961;border:2px solid #c79098}.table-button:hover{opacity:.8}.status-badge{display:inline-flex;align-items:center;justify-content:center;padding:6px 10px;border-radius:999px;font-size:12px;font-weight:700;line-height:1}.status-badge--active{background:#eef2fb;color:#4f6299;border:2px solid #7b8fc7}.status-badge--leave{background:#faf6e9;color:#8a7440;border:2px solid #d8c27a}.status-badge--graduated{background:#f4f6f8;color:#46535ab8;border:2px solid rgba(70,83,90,.08)}.status-badge--withdrawn{background:#fbf0f2;color:#8a5961;border:2px solid #c79098}.ui-pagination{display:flex;align-items:center;justify-content:center;flex-direction:column;gap:8px;flex-wrap:wrap;margin-top:24px}.ui-pagination__summary{font-size:.95rem;color:#46535ab8}.ui-pagination__list{display:flex;align-items:center;gap:10px;margin:0;padding:0;list-style:none}.ui-pagination__item{display:flex}.ui-pagination__link{display:inline-flex;align-items:center;justify-content:center;min-width:44px;height:44px;padding:0 14px;border:1px solid rgba(123,143,199,.16);border-radius:14px;background:#fff;color:#2b3140;text-decoration:none;font-weight:700;transition:border-color .2s ease,background .2s ease,color .2s ease,opacity .2s ease}.ui-pagination__item:not(.ui-pagination__item--active):not(.ui-pagination__item--disabled) .ui-pagination__link:hover{border-color:#7b8fc747;background:#eef2fb}.ui-pagination__item--active .ui-pagination__link{border-color:#b7a6d9;background:#f4effb;color:#756394}.ui-pagination__item--disabled .ui-pagination__link{background:#f7f8fb;color:#46535a61;opacity:.7;cursor:default}.ui-pagination__item--dots .ui-pagination__link{min-width:auto;padding:0 6px;border:none;background:transparent}@media(max-width:768px){.ui-pagination{gap:12px}.ui-pagination__summary{width:100%;text-align:center;font-size:.9rem}.ui-pagination__list{gap:8px}.ui-pagination__link{min-width:40px;height:40px;padding:0 12px;border-radius:12px}}.table-scroll-wrap{max-height:520px;overflow:auto}.table-scroll-wrap .base-table{width:100%;min-width:960px;border-collapse:separate;border-spacing:0}.table-scroll-wrap .base-table thead th{position:sticky;top:0;z-index:2;background:#f6f7fc}.table-scroll-wrap .base-table th,.table-scroll-wrap .base-table td{white-space:nowrap}.ui-form{display:flex;flex-direction:column}.ui-form-section{padding:24px;border:1px solid rgba(123,143,199,.12);border-radius:8px;background:#fff;box-shadow:0 10px 30px #46535a0d;margin-bottom:8px}.ui-form-section-header{margin-bottom:18px}.ui-form-section-eyebrow{margin:0;font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#7b8fc7}.ui-form-section-title{margin:0;font-size:16px;font-weight:800;color:#2b3140}.ui-form-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:18px 20px;margin-bottom:12px}.ui-form-field--full{grid-column:1/-1}.form-help{padding-left:12px;font-size:10px;color:#666}.ui-selection-panel{border-radius:4px;background:#fcfdff}.ui-checkbox-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(100px,1fr));gap:10px}.ui-checkbox-tile{display:flex;align-items:center;gap:8px;padding:4px;border-radius:50px;border:2px solid #8eb7b0;background:#fff;font-size:12px;color:#587f79;letter-spacing:.08em;transition:border-color .2s ease,background .2s ease,box-shadow .2s ease}.ui-checkbox-tile input[type=checkbox]{position:absolute;opacity:0;pointer-events:none}.ui-checkbox-tile span{display:block;width:100%;text-align:center}.ui-checkbox-tile:hover{border-color:#8eb7b0;background:#edf7f5}.ui-checkbox-tile:has(input[type=checkbox]:checked){border-color:#8eb7b0;background:#8eb7b0;color:#fff;font-weight:semi-bold}.ui-checkbox-tile:has(input[type=checkbox]:focus-visible){box-shadow:0 0 0 4px #8eb7b0}.ui-stack-list{display:flex;flex-direction:column;gap:12px;margin-bottom:14px}.ui-stack-list-row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:12px;align-items:center}.ui-item-list{display:flex;flex-direction:column;gap:18px;margin-bottom:16px}.ui-item-card{padding:18px;border:2px solid #8eb7b0;border-radius:8px;background:linear-gradient(180deg,#fff,#fbfcfe)}.ui-item-card-header{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:16px}.ui-item-card-title{font-size:.95rem;font-weight:800;color:#2b3140}.form-label{margin-bottom:8px;display:inline-block;font-size:.92rem;font-weight:700;color:#2b3140}.form-input{width:100%;min-height:40px;padding:4px 12px;border:2px solid rgba(123,143,199,.16);border-radius:50px;background:#fff;color:#2b3140;transition:border-color .2s ease,box-shadow .2s ease,background .2s ease}select.form-input{font-size:13px}.form-input:focus{outline:none;border:2px solid #8eb7b0;box-shadow:0 0 0 4px #edf7f5}textarea.form-input{min-height:120px;resize:vertical;border-radius:4px}.form-error{margin-top:6px;font-size:.85rem;color:#9a5d6b}.confirm-button{display:inline-flex;align-items:center;justify-content:center;padding:8px 12px;margin-bottom:12px;border-radius:8px;font-size:12px;font-weight:700;transition:background-color .2s ease,transform .2s ease}.confirm-button-register{background-color:#faf6e9;color:#8a7440;border:2px solid #8a7440}.confirm-button:hover{opacity:.8}.remove-button{min-width:5em}@media(max-width:768px){.ui-form-section{padding:18px;border-radius:16px}.ui-form-grid{grid-template-columns:1fr;gap:16px}.ui-checkbox-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}.ui-filter-form{gap:0}.ui-filter-form__section{padding:20px 24px}.ui-filter-form-actions{margin-top:16px;display:flex;gap:10px;flex-wrap:wrap}@media(max-width:768px){.ui-filter-form__section{padding:18px}}.auth-card{width:100%;max-width:560px}.auth-card__header{margin-bottom:20px}.auth-form__section{padding:0;border:none;box-shadow:none;background:transparent}.auth-form-actions{margin-top:4px}.ui-check-row{display:inline-flex;align-items:center;gap:10px;min-height:44px;cursor:pointer}.ui-check-row__input{width:18px;height:18px;accent-color:#7b8fc7}.ui-check-row__label{font-size:.95rem;color:#2b3140}.auth-button{display:inline-flex;align-items:center;justify-content:center;padding:8px 12px;border-radius:8px;font-size:12px;font-weight:700;transition:background-color .2s ease,transform .2s ease}.auth-button-login{background-color:#eef2fb;color:#4f6299;border:2px solid #7b8fc7}.auth-button-logout{background-color:#fbf0f2;color:#8a5961;border:2px solid #c79098}.auth-button:hover{opacity:.8}@media(max-width:768px){.auth-page{padding:24px 12px}}.auth-page{display:flex;justify-content:center;padding:40px 16px}.auth-card{width:100%;max-width:420px;padding:24px;border:1px solid #ddd;border-radius:12px;background:#fff}.auth-card-title{margin-bottom:20px;font-size:24px}.auth-form{width:100%}.dashboard-header{margin-bottom:24px}.dashboard-title{font-size:30px;font-weight:700;color:#2b3140;margin-bottom:8px;letter-spacing:.01em}.dashboard-stats{gap:12px;margin-bottom:12px;display:flex;flex-wrap:wrap}.stat-card{display:flex;justify-content:flex-start;align-items:baseline;gap:12px;border-radius:8px;padding:12px;flex:1}.stat-card-label{font-size:14px;color:#6d7485;width:5.5em}.stat-card-value{font-size:16px;line-height:1;font-weight:700;color:#2b3140}.stat-card-students{background-color:#eef2fb}.stat-card-teachers{background-color:#edf7f5}.stat-card-records{background-color:#f4effb}@media screen and (max-width:700px){.dashboard-stats{flex-direction:column}}.panel-table th{background:#f3f5fb;color:#6d7485;font-weight:600;letter-spacing:.02em}.panel-table td{background:#fff;color:#2b3140}.panel-table tbody tr:hover td{background:#fafbfe}.panel-table-name{font-weight:700}.panel-table.student-name a{display:inline-block;border-bottom:1px solid #2b3140}.panel-table-name.student-name a,.panel-table-name.teacher-name a{display:inline-block;border-bottom:1px solid #2b3140;padding:4px}.record-count-badge{display:inline-flex;align-items:center;justify-content:center;text-align:center;width:32px;height:32px;border-radius:999px;background:#eef2fb;color:#4f6299;font-size:12px;font-weight:700;aspect-ratio:1;line-height:1}.dashboard-table__more,.school-more-badge{text-align:center;color:#7b8fc7;font-size:10px;font-weight:700;aspect-ratio:1;line-height:1;margin-left:8px}.empty-state{padding:28px 20px;border-radius:8px;background:#f3f5fb;color:#6d7485}.text-muted{color:#6d7485}.ui-detail-section{padding:24px;border:1px solid rgba(123,143,199,.12);border-radius:12px;background:#fff;box-shadow:0 10px 30px #46535a0d;margin-bottom:8px}.ui-detail-section-header{margin-bottom:18px}.ui-detail-section-eyebrow{margin:0 0 6px;font-size:.8rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#7b8fc7}.ui-detail-section-title{margin:0;font-size:1.15rem;font-weight:800;color:#2b3140}.ui-detail-list{display:flex;flex-direction:column;gap:0}.ui-detail-list-row{display:grid;grid-template-columns:180px minmax(0,1fr);gap:18px;align-items:start;padding:14px 0;border-top:1px solid rgba(123,143,199,.08)}.ui-detail-list-row:first-child{border-top:none;padding-top:0}.ui-detail-list__label{font-size:13px;font-weight:700;color:#46535ac7}.ui-detail-list-value{font-size:13px;line-height:1.7;color:#2b3140;min-width:0}.ui-detail-list-value .name-kana{font-size:10px}.ui-status-chip{display:inline-flex;align-items:center;min-height:30px;padding:4px 10px;border-radius:999px;font-size:10px;font-weight:700;border:2px solid transparent}.ui-status-chip--primary{background:#eef2fb;color:#4f6299;border-color:#7b8fc7}.ui-status-chip--secondary{background:#edf7f5;color:#587f79;border-color:#8eb7b0}.ui-status-chip--accent{background:#faf6e9;color:#8a7440;border-color:#d8c27a}.ui-status-chip--muted{background:#fbf0f2;color:#8a5961;border:2px solid #c79098}.chip-list{display:flex;flex-wrap:wrap;gap:8px}.chip{display:inline-flex;align-items:center;padding:4px 8px;border:2px solid #8eb7b0;border-radius:999px;background:#edf7f5;color:#5f8d84;font-size:12px;font-weight:600}@media(max-width:768px){.ui-detail-section{padding:18px;border-radius:16px}.ui-detail-list-row{grid-template-columns:1fr;gap:6px;padding:12px 0}.ui-detail-list__label{font-size:.86rem}.ui-detail-list-value{font-size:.95rem}}.ui-record-list{display:flex;flex-direction:column;gap:8px}.ui-record-card{border-radius:50px 4px 8px 8px;background:#fff;overflow:hidden;box-shadow:#00000005 0 1px 3px,#1b1f2326 0 0 0 1px;border:1px solid rgba(123,143,199,.12);box-shadow:0 10px 30px #46535a0d}.ui-record-card__header{display:flex;justify-content:space-between;align-items:flex-start;gap:18px;padding:20px 24px;background:#eef2fb;border-top:8px solid #7b8fc7}.ui-record-card__header-main{min-width:0}.ui-record-card__title{font-size:1.08rem;font-weight:700;color:#2b3140}.ui-record-card__meta{margin:0;font-size:.92rem;color:#46535ab8}.ui-record-card-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.ui-record-card__body{display:flex;flex-direction:column;gap:8px;padding:22px 24px 24px}.ui-record-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}.ui-record-block{padding:16px 18px;border:1px solid rgba(123,143,199,.1);border-radius:4px;background:#fcfdff}.ui-record-title{font-size:16px;color:#2b3140;font-weight:700;padding-left:.5em;margin-top:8px;border-left:4px solid #7b8fc7}.ui-record-block--subject{background:#fff}.ui-record-block__title{margin:0 0 10px;font-size:12px;font-weight:700;color:#6d7485}.ui-record-block__content{font-size:.95rem;line-height:1.8;color:#2b3140;white-space:normal;word-break:break-word}.ui-record-meta{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.ui-record-meta__item{display:flex;align-items:center;gap:6px;padding:14px 16px;border-radius:4px;background:#f7f8fb}.ui-record-meta__label{font-size:12px;font-weight:700;letter-spacing:.03em;color:#666;min-width:6em}.ui-record-meta__value{font-size:.98rem;font-weight:700;color:#2b3140}.ui-record-subject-list{display:flex;flex-direction:column;gap:8px}@media(max-width:768px){.ui-record-card{border-radius:16px}.ui-record-card__header{flex-direction:column;align-items:stretch;padding:18px}.ui-record-card__body{padding:18px;gap:8px}.ui-record-grid,.ui-record-meta{grid-template-columns:1fr}}.ui-record-card{border:1px solid rgba(123,143,199,.12);border-radius:8px 8px 4px 4px;background:#fff;overflow:hidden;box-shadow:0 10px 30px #46535a0d}.ui-record-card__summary{list-style:none;display:flex;justify-content:space-between;align-items:center;gap:8px;padding:10px 12px;cursor:pointer;background-color:#eef2fb}.ui-record-card__summary::-webkit-details-marker{display:none}.ui-record-card__summary:hover{opacity:.8}.ui-record-card__summary-side{display:flex;align-items:center;gap:14px}.ui-record-card__toggle-indicator{position:relative;width:18px;height:18px;flex:0 0 18px}.ui-record-card__toggle-indicator:before,.ui-record-card__toggle-indicator:after{content:"";position:absolute;top:50%;left:50%;width:10px;height:2px;border-radius:999px;background:#2b3140;transform-origin:center;transition:transform .2s ease,opacity .2s ease}.ui-record-card__toggle-indicator:before{transform:translate(-50%,-50%) rotate(0)}.ui-record-card__toggle-indicator:after{transform:translate(-50%,-50%) rotate(90deg)}.ui-record-card[open] .ui-record-card__toggle-indicator:after{opacity:0;transform:translate(-50%,-50%) rotate(90deg) scaleX(0)}.ui-record-card__body{display:flex;flex-direction:column;gap:12px;padding:22px 24px 24px}.ui-record-card-actions{display:flex;justify-content:flex-end;gap:10px;flex-wrap:wrap}.ui-record-meta--compact{display:flex;gap:10px}.ui-record-meta--compact .ui-record-meta__item{min-width:140px;padding:10px 12px}@media(max-width:768px){.ui-record-card{border-radius:16px}.ui-record-card__summary{align-items:stretch;padding:18px}.ui-record-card__summary-side{flex-direction:column;align-items:stretch}.ui-record-meta--compact{flex-direction:column}.ui-record-card__body{padding:18px;gap:16px}.ui-record-card-actions{justify-content:stretch}}.ui-course-chip{display:inline-flex;align-items:center;border-radius:999px;font-size:13px;font-weight:700;line-height:1;border:1px solid transparent;vertical-align:center}.ui-course-chip--liberal-arts{color:#756394}.ui-course-chip--science{color:#587f79}.ui-course-chip--other{color:#8a6b3f}.ui-course-chip--muted{color:#46535ab8}.assigned-teacher-summary-list{display:flex;flex-direction:column;gap:12px}.assigned-teacher-summary-item{display:flex;flex-wrap:wrap;align-items:center;gap:10px 12px}.assigned-teacher-summary-item__name{font-weight:700;color:#2b3140;min-width:5em}
