*{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;text-size-adjust:100%}body{font-family:Noto Sans JP,sans-serif;background:#f5f7f8;overflow-x:hidden;max-width:100vw}body.app-nav-open{overflow:hidden}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:#f1f1f1}::-webkit-scrollbar-thumb{background:#ccc;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#aaa}button:focus{outline:none}input:focus,textarea:focus,select:focus{outline:2px solid #009688;outline-offset:1px}img,video,svg{max-width:100%;height:auto}.app-shell{display:flex;flex-direction:column;height:100vh;height:100dvh;font-family:Noto Sans JP,sans-serif;overflow:hidden;max-width:100vw}.app-shell-top{flex-shrink:0;z-index:200}.app-shell-body{display:flex;flex:1;min-height:0;min-width:0;position:relative;overflow:hidden}.app-sidebar-backdrop{display:none;position:fixed;right:0;bottom:0;left:0;top:0;background:#00000073;z-index:280;border:none;padding:0;cursor:pointer}.app-sidebar-backdrop.is-visible{display:block}.app-sidebar{width:200px;flex-shrink:0;background:#fff;border-right:1px solid #e0e0e0;display:flex;flex-direction:column;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;z-index:300}.app-sidebar-close{display:none}.app-sidebar-nav-item{display:flex;align-items:center;gap:8px;width:100%;padding:11px 16px;background:none;border:none;border-left:4px solid transparent;text-align:left;cursor:pointer;font-size:14px;color:#444;font-weight:400;transition:background .15s,color .15s,border-color .15s;touch-action:manipulation;min-height:44px}.app-sidebar-nav-item.is-active{background:#e3f8f5;color:#007060;font-weight:700;border-left-color:#009688}.app-sidebar-mascot{margin-top:auto;padding:12px 0;text-align:center;border-top:1px solid #f0f0f0}.app-main{flex:1;min-width:0;overflow-y:auto;overflow-x:hidden;background:#f5f7f8;-webkit-overflow-scrolling:touch}.app-main-inner{width:100%;max-width:100%;min-height:100%;box-sizing:border-box;padding:clamp(12px,1.8vw,28px)}.app-header{background:#009688;color:#fff;display:flex;align-items:center;padding:0 12px;min-height:50px;gap:8px;flex-shrink:0;box-shadow:0 2px 4px #0003;flex-wrap:wrap}.app-header-menu-btn{display:none;align-items:center;justify-content:center;width:44px;height:44px;min-width:44px;min-height:44px;padding:0;border:none;background:#ffffff26;color:#fff;border-radius:8px;cursor:pointer;font-size:22px;line-height:1;touch-action:manipulation;flex-shrink:0}.app-header-greeting{font-size:clamp(12px,3.2vw,13px);flex:1 1 120px;min-width:0;line-height:1.35}.app-header-date{display:flex;align-items:center;justify-content:center;gap:8px;flex:1 1 auto;min-width:0}.app-header-date-label{font-size:clamp(14px,3.8vw,17px);font-weight:700;letter-spacing:.3px;text-align:center;line-height:1.3}.app-header-date-btn{background:none;border:none;color:#fff;font-size:24px;cursor:pointer;line-height:1;padding:0;min-width:44px;min-height:44px;display:inline-flex;align-items:center;justify-content:center;touch-action:manipulation;flex-shrink:0}.app-header-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:flex-end;margin-left:auto}.app-header-notif-btn{border:1px solid rgba(255,255,255,.6);background:#ffffff1a;color:#fff;border-radius:14px;padding:8px 12px;font-size:12px;cursor:pointer;position:relative;touch-action:manipulation;min-height:44px;line-height:1.3}.app-header-notif-btn--plain{font-size:13px;background:none;border:none;padding:8px 4px;min-height:44px}.app-header-logout{background:none;border:1px solid rgba(255,255,255,.6);color:#fff;padding:8px 14px;border-radius:4px;cursor:pointer;font-size:13px;touch-action:manipulation;min-height:44px;white-space:nowrap}.app-header-notif-badge{background:#f44336;color:#fff;border-radius:10px;font-size:10px;padding:1px 5px;position:absolute;top:-6px;right:-8px}.student-furigana-bar{flex-shrink:0;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:8px clamp(12px,3vw,20px);background:#e8f5f3;border-bottom:1px solid #B2DFDB;font-size:clamp(13px,3.5vw,14px);color:#00695c;flex-wrap:wrap}.app-teacher-subbar{border-bottom:1px solid #e0e0e0;background:#fff;padding:8px clamp(12px,3vw,20px);flex-shrink:0}.app-teacher-subbar-inner{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.app-teacher-subbar select{font-size:14px;padding:10px 12px;border:1px solid #ccc;border-radius:6px;min-height:44px;max-width:100%;flex:1 1 160px}.app-consult-picker{border-bottom:1px solid #e0e0e0;background:#fff8e1;padding:12px clamp(12px,3vw,20px);flex-shrink:0}.app-consult-picker-btn{display:flex;align-items:center;justify-content:space-between;width:100%;padding:12px 14px;border-radius:8px;border:1px solid #FFE082;background:#fff;cursor:pointer;font-size:14px;color:#333;text-align:left;min-height:44px;touch-action:manipulation}.app-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:1000;padding:max(12px,env(safe-area-inset-top)) max(12px,env(safe-area-inset-right)) max(12px,env(safe-area-inset-bottom)) max(12px,env(safe-area-inset-left))}.app-modal-panel{background:#fff;border-radius:12px;padding:clamp(16px,4vw,28px);width:100%;max-width:520px;max-height:min(85vh,85dvh);overflow-y:auto;box-shadow:0 8px 32px #0003;-webkit-overflow-scrolling:touch}.app-modal-title{font-size:clamp(16px,4vw,17px);font-weight:700;margin-bottom:20px;text-align:center;color:#333}.btn-primary,.btn-secondary{touch-action:manipulation;min-height:44px;font-size:clamp(14px,3.6vw,15px)}.btn-primary{background:#009688;color:#fff;border:none;padding:10px 28px;border-radius:6px;cursor:pointer;font-weight:600}.btn-primary:disabled{background:#bbb;cursor:default}.btn-secondary{background:#fff;color:#009688;border:1.5px solid #009688;padding:10px 24px;border-radius:6px;cursor:pointer;font-weight:500}.app-card{background:#fff;border-radius:8px;padding:clamp(14px,3vw,20px);box-shadow:0 1px 4px #00000014;max-width:100%}.app-card.app-table-scroll{padding:0}.app-table-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch;max-width:100%}.app-table-scroll table{width:100%;border-collapse:collapse}.login-page{min-height:100vh;min-height:100dvh;background:linear-gradient(135deg,#e0f2f1,#b2ebf2);display:flex;align-items:center;justify-content:center;padding:max(16px,env(safe-area-inset-top)) max(16px,env(safe-area-inset-right)) max(16px,env(safe-area-inset-bottom)) max(16px,env(safe-area-inset-left))}.login-card{background:#fff;border-radius:16px;padding:clamp(24px,6vw,40px);width:100%;max-width:440px;box-shadow:0 8px 32px #00968826}.login-card h1{font-size:clamp(18px,5vw,22px)}.login-role-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:24px}.login-role-btn{padding:14px 4px;border-radius:10px;cursor:pointer;touch-action:manipulation;min-height:44px;font-size:clamp(12px,3.2vw,14px)}.login-card input,.login-card textarea,.login-card select{width:100%;border:1.5px solid #ddd;border-radius:6px;padding:12px 14px;font-size:16px;margin-bottom:10px;min-height:44px}.app-main input:not([type=checkbox]):not([type=radio]):not([type=hidden]),.app-main select,.app-main textarea{font-size:16px;min-height:44px}.app-main .app-table-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch;max-width:100%}.login-card textarea{min-height:80px}.login-submit{width:100%;background:#009688;color:#fff;border:none;border-radius:8px;padding:14px 0;font-size:16px;font-weight:700;cursor:pointer;margin-top:12px;min-height:48px;touch-action:manipulation}.login-admin-code-row{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:10px}.login-admin-code-row input{flex:1 1 140px;margin-bottom:0;min-width:0}.login-admin-code-row button{min-height:44px;padding:0 12px;font-size:12px;font-weight:700;border-radius:6px;cursor:pointer;touch-action:manipulation;flex:1 1 auto}.app-flex-wrap{display:flex;flex-wrap:wrap;gap:12px}.app-grid-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(100%,200px),1fr));gap:16px}.app-grid-stamps{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(100%,80px),1fr));gap:8px}.app-grid-subjects{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(100%,130px),1fr));gap:8px}@media (min-width: 768px){.app-header{padding:0 20px;flex-wrap:nowrap;min-height:50px}.app-header-greeting{flex:0 1 auto;white-space:nowrap}.app-header-date-label{white-space:nowrap}.app-sidebar{position:static;transform:none}}@media (max-width: 767px){.app-header-menu-btn{display:inline-flex}.app-header{row-gap:4px;padding-top:6px;padding-bottom:6px}.app-header-greeting{order:2;flex:1 1 100%}.app-header-date{order:1;flex:1 1 auto;justify-content:center}.app-header-actions{order:3;width:100%;justify-content:flex-end;margin-left:0}.app-header-notif-btn{font-size:11px;padding:8px 10px}.app-sidebar{position:fixed;top:0;left:0;bottom:0;width:min(280px,88vw);max-width:100%;transform:translate(-105%);transition:transform .25s ease;box-shadow:4px 0 24px #00000026}.app-sidebar.is-open{transform:translate(0)}.app-sidebar-close{display:flex;align-items:center;justify-content:center;margin:8px 12px 0 auto;width:44px;height:44px;border:none;background:#f5f5f5;border-radius:8px;font-size:20px;cursor:pointer;touch-action:manipulation}.login-role-grid{grid-template-columns:1fr}.app-grid-subjects-4{grid-template-columns:repeat(2,1fr)!important}}@media (max-width: 480px){.app-main-inner,.app-card{padding:12px}.app-header-actions{gap:6px}.app-header-notif-btn span:not(.app-header-notif-badge){max-width:72px;overflow:hidden;text-overflow:ellipsis;display:inline-block;vertical-align:middle}}.parent-portal-root{-webkit-tap-highlight-color:transparent}.parent-portal-login .parent-login-card{max-width:min(420px,100%)}.parent-portal-tabs{flex-shrink:0;overflow-x:auto;-webkit-overflow-scrolling:touch;overscroll-behavior-x:contain;scrollbar-width:thin}.parent-portal-tabs::-webkit-scrollbar{height:4px}.parent-portal-tab{touch-action:manipulation;min-height:44px}.parent-table-card{touch-action:pan-x}.parent-data-table th,.parent-data-table td{padding:10px 8px;font-size:14px}.parent-data-table td{word-break:break-word}@media (max-width: 720px){.parent-portal-root>header{flex-wrap:wrap;height:auto!important;min-height:50px;row-gap:8px;column-gap:10px;padding:10px 12px!important;align-items:center}.parent-portal-root>header>span:first-of-type{flex:1 1 100%;min-width:0!important;white-space:normal!important;line-height:1.45;font-size:clamp(11px,3.2vw,13px)!important}.parent-portal-root>header>div:first-of-type{flex:1 1 auto;min-width:0;justify-content:center;gap:12px}.parent-portal-root>header>div:first-of-type button{min-width:44px;min-height:44px;padding:0 10px!important;display:inline-flex;align-items:center;justify-content:center}.parent-portal-root>header>div:first-of-type span{white-space:normal!important;text-align:center;font-size:clamp(14px,3.8vw,17px)!important;line-height:1.3}.parent-portal-root>header>div:last-of-type{margin-left:auto;flex-shrink:0}.parent-portal-root>header>div:last-of-type button{min-height:44px;padding:8px 14px!important;font-size:14px!important}}@media (max-width: 520px){.parent-health-row{flex-direction:column}.parent-health-row>*{width:100%;flex:1 1 auto!important}.parent-data-table th,.parent-data-table td{padding:9px 6px;font-size:13px}}
