*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}
  :root{
    --sky:#6ba3d0; --sky-d:#4f8ec0; --sky-text:#3b7bb5;
    --sky-bg:#e8f1fa; --ink:#2c3540; --gray:#8b95a1; --gray2:#b6c0cc;
    --line:#eef2f6; --bg:#f4f7fb; --card:#fff;
    --red:#e0586b; --green:#3aa981; --yellow:#e89c3c;
    font-family:'Pretendard','Apple SD Gothic Neo',sans-serif;
  }
  body{background:var(--bg);min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:24px 16px;color:var(--ink)}

  .login-wrap{width:100%;max-width:400px}

  /* 상단 로고/타이틀 */
  .brand{text-align:center;margin-bottom:28px}
  .brand img{width:150px;height:auto;object-fit:contain;margin-bottom:14px}
  .brand h1{font-size:26px;font-weight:800;letter-spacing:-.03em;color:var(--ink)}
  .brand p{font-size:14px;font-weight:600;color:var(--gray);margin-top:6px}

  /* 카드 */
  .card{background:var(--card);border-radius:24px;padding:26px 22px;box-shadow:0 8px 30px rgba(43,53,64,.08)}

  /* 버튼 공통 */
  .btn{width:100%;border:none;font:inherit;font-size:16px;font-weight:700;
       padding:17px;border-radius:15px;cursor:pointer;display:flex;align-items:center;
       justify-content:center;gap:10px;transition:transform .12s ease, background .12s ease, opacity .12s}
  .btn:active{transform:scale(.97)}
  .btn:disabled{opacity:.5;cursor:default}
  .btn-google{background:var(--card);color:var(--ink);border:1.5px solid var(--line);margin-bottom:12px}
  .btn-google:hover{background:#fafcfe}
  .btn-primary{background:var(--sky-d);color:#fff}
  .btn-ghost{background:transparent;color:var(--sky-text);font-weight:700;font-size:14px;padding:12px}

  .gicon{width:20px;height:20px;flex-shrink:0}

  /* 구분선 */
  .divider{display:flex;align-items:center;gap:12px;margin:18px 2px;color:var(--gray2);font-size:13px;font-weight:600}
  .divider::before,.divider::after{content:"";flex:1;height:1px;background:var(--line)}

  /* 이메일 영역 */
  .email-area{display:none;animation:slide .3s ease}
  .email-area.show{display:block}
  @keyframes slide{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:none}}
  .email-title{font-size:15px;font-weight:800;color:var(--ink);margin-bottom:14px}
  .field{margin-bottom:12px}
  .field label{display:block;font-size:13px;font-weight:700;color:var(--gray);margin:0 0 7px 4px}
  .field input,.field textarea{width:100%;background:var(--bg);border:1.5px solid transparent;border-radius:14px;
       padding:16px;font:inherit;font-size:16px;color:var(--ink);transition:border-color .15s, background .15s}
  .field textarea{resize:vertical;line-height:1.5;min-height:64px}
  .field input:focus,.field textarea:focus{outline:none;background:var(--card);border-color:var(--sky-d)}
  .field input::placeholder,.field textarea::placeholder{color:var(--gray2)}

  .toggle-line{text-align:center;margin-top:6px;font-size:13px;color:var(--gray);font-weight:600}
  .toggle-line button{background:none;border:none;font:inherit;font-size:13px;font-weight:800;
       color:var(--sky-text);cursor:pointer;padding:4px 6px}

  /* 메시지 */
  .msg{font-size:13px;font-weight:600;text-align:center;min-height:18px;margin-top:12px;line-height:1.5}
  .msg.err{color:var(--red)}
  .msg.ok{color:var(--green)}

  /* 로그인 성공 패널 (테스트용) */
  .done{display:none;text-align:center}
  .done.show{display:block;animation:slide .3s ease}
  .done .check{width:64px;height:64px;border-radius:50%;background:var(--sky-bg);color:var(--sky-d);
       display:grid;place-items:center;margin:4px auto 16px}
  .done h2{font-size:20px;font-weight:800;color:var(--ink);margin-bottom:6px}
  .done .who{font-size:14px;color:var(--gray);font-weight:600;line-height:1.6;margin-bottom:8px}
  .done .uid{font-size:11px;color:var(--gray2);word-break:break-all;background:var(--bg);
       padding:10px 12px;border-radius:10px;margin-bottom:18px}
  .done .note{font-size:13px;color:var(--sky-text);font-weight:600;background:var(--sky-bg);
       padding:12px 14px;border-radius:12px;line-height:1.5;margin-bottom:18px}

  /* 가입 신청 화면 */
  .signup{display:none}
  .signup.show{display:block;animation:slide .3s ease}
  .signup h2{font-size:20px;font-weight:800;color:var(--ink);text-align:center;margin-bottom:6px}
  .signup .sub{font-size:13px;color:var(--gray);font-weight:600;text-align:center;line-height:1.5;margin-bottom:18px}
  .signup .who{font-size:12px;color:var(--gray2);text-align:center;background:var(--bg);
       padding:9px 12px;border-radius:10px;margin-bottom:18px;word-break:break-all}

  /* 역할 선택 토글 */
  .role-select{display:flex;gap:10px}
  .role-btn{flex:1;padding:15px;border-radius:14px;border:1.5px solid var(--line);background:var(--bg);
       font:inherit;font-size:15px;font-weight:700;color:var(--gray);cursor:pointer;
       transition:background .15s,border-color .15s,color .15s}
  .role-btn:active{transform:scale(.97)}
  .role-btn.active{background:var(--sky-bg);border-color:var(--sky-d);color:var(--sky-text)}

  /* 관리자 승인 화면 */
  .admin{display:none}
  .admin.show{display:block;animation:slide .3s ease}
  .admin h2{font-size:20px;font-weight:800;color:var(--ink);text-align:center;margin-bottom:6px}
  .admin .sub{font-size:13px;color:var(--gray);font-weight:600;text-align:center;margin-bottom:18px}
  .admin .sub b{color:var(--sky-text)}
  .pending-list{display:flex;flex-direction:column;gap:10px;margin-bottom:14px;max-height:52vh;overflow-y:auto}
  .pending-row{display:flex;flex-direction:column;align-items:stretch;gap:5px;
       background:var(--bg);border-radius:14px;padding:13px 14px}
  .p-name{font-size:15px;font-weight:800;color:var(--ink);display:flex;align-items:center;gap:7px}
  .p-role{font-size:11px;font-weight:700;color:var(--sky-text);background:var(--sky-bg);padding:2px 8px;border-radius:8px}
  .p-phone{font-size:12px;color:var(--gray);font-weight:600;word-break:break-all}
  .p-note{font-size:12px;color:var(--sky-text);font-weight:600;margin-top:2px;background:var(--sky-bg);
       padding:6px 9px;border-radius:8px;line-height:1.45;white-space:pre-wrap;word-break:break-word}
  .p-controls{display:flex;gap:6px;align-items:center;margin-top:8px}
  .p-role-sel{flex:1;min-width:0;padding:9px 10px;border-radius:10px;border:1.5px solid var(--line);
       background:var(--card);font:inherit;font-size:13px;font-weight:700;color:var(--ink);cursor:pointer}
  .p-role-sel:focus{outline:none;border-color:var(--sky-d)}
  .p-link-sel{width:100%;margin-top:8px;padding:9px 10px;border-radius:10px;border:1.5px solid var(--line);
       background:var(--card);font:inherit;font-size:13px;font-weight:700;color:var(--ink);cursor:pointer}
  .p-link-sel:focus{outline:none;border-color:var(--sky-d)}
  .p-controls button{border:none;font:inherit;font-size:13px;font-weight:700;padding:9px 14px;
       border-radius:10px;cursor:pointer;transition:opacity .12s;flex-shrink:0}
  .p-controls button:active{transform:scale(.95)}
  .p-controls button:disabled{opacity:.5;cursor:default}
  .p-ok{background:var(--green);color:#fff}
  .p-no{background:var(--red);color:#fff}
  .p-tag{font-size:12px;font-weight:800}
  .p-tag.ok{color:var(--green)}
  .p-tag.no{color:var(--red)}
  .empty{text-align:center;color:var(--gray);font-size:13px;font-weight:600;padding:24px 0}

  /* 반/학생 보기 */
  .roster{display:none}
  .roster.show{display:block;animation:slide .3s ease}
  .roster-head{display:flex;align-items:center;gap:8px;margin-bottom:4px}
  .roster-head h2{font-size:20px;font-weight:800;color:var(--ink)}
  .back-btn{border:none;background:var(--bg);color:var(--ink);width:34px;height:34px;border-radius:10px;
       font-size:22px;font-weight:800;cursor:pointer;line-height:1;flex-shrink:0;display:grid;place-items:center}
  .back-btn:active{transform:scale(.93)}
  .roster-list{display:flex;flex-direction:column;gap:9px;margin:14px 0;max-height:54vh;overflow-y:auto}
  .r-row{display:flex;align-items:center;justify-content:space-between;gap:10px;background:var(--bg);
       border-radius:14px;padding:14px;cursor:pointer;transition:background .12s}
  .r-row:active{transform:scale(.99)}
  .r-row.tap:hover{background:var(--sky-bg)}
  .r-main{min-width:0}
  .r-name{font-size:15px;font-weight:800;color:var(--ink)}
  .r-meta{font-size:12px;color:var(--gray);font-weight:600;margin-top:3px;word-break:break-all}
  .r-badge{font-size:12px;font-weight:800;color:var(--sky-text);background:var(--sky-bg);
       padding:4px 10px;border-radius:10px;flex-shrink:0}
  .r-arrow{color:var(--gray2);font-size:18px;font-weight:800;flex-shrink:0}

  /* 학생 상세 */
  .sec-title{font-size:13px;font-weight:800;color:var(--sky-text);margin:14px 2px 8px;}
  .stat-row{display:flex;gap:8px;margin-bottom:6px}
  .stat{flex:1;background:var(--bg);border-radius:12px;padding:10px 4px;text-align:center}
  .stat-n{font-size:20px;font-weight:800;line-height:1.1}
  .stat-l{font-size:11px;font-weight:700;color:var(--gray);margin-top:3px}
  .stat.green .stat-n{color:var(--green)} .stat.red .stat-n{color:var(--red)}
  .stat.yellow .stat-n{color:var(--yellow)} .stat.gray .stat-n{color:var(--gray)}
  .d-line{display:flex;justify-content:space-between;gap:10px;padding:9px 12px;background:var(--bg);
       border-radius:10px;margin-bottom:6px;font-size:13px}
  .d-date{color:var(--gray);font-weight:700;flex-shrink:0}
  .d-val{color:var(--ink);font-weight:600;text-align:right;word-break:break-all}
  .d-empty{color:var(--gray2);font-size:13px;font-weight:600;padding:8px 12px}

  /* 출석 입력 */
  .attend{display:none}
  .attend.show{display:block;animation:slide .3s ease}
  .attend-list{display:flex;flex-direction:column;gap:10px;margin:10px 0 14px;max-height:50vh;overflow-y:auto}
  .a-row{background:var(--bg);border-radius:14px;padding:11px 12px}
  .a-name{font-size:14px;font-weight:800;color:var(--ink);margin-bottom:8px}
  .seg{display:flex;gap:4px;background:var(--line);border-radius:11px;padding:3px}
  .seg button{flex:1;border:none;background:transparent;font:inherit;font-size:13px;font-weight:700;
       color:var(--gray);padding:8px 4px;border-radius:9px;cursor:pointer;transition:background .12s,color .12s}
  .seg button.on{background:var(--card);color:var(--sky-text);box-shadow:0 1px 4px rgba(0,0,0,.06)}
  .seg button.on[data-st="결석"]{color:var(--red)}
  .seg button.on[data-st="지각"]{color:var(--yellow)}
  .seg button.on[data-st="조퇴"]{color:var(--ink)}
  .a-reason{width:100%;margin-top:8px;background:var(--card);border:1.5px solid var(--line);border-radius:10px;
       padding:10px 12px;font:inherit;font-size:13px;color:var(--ink);display:none}
  .a-reason.show{display:block}
  .a-reason:focus{outline:none;border-color:var(--sky-d)}

  /* 과제 */
  .hw{display:none}
  .hw.show{display:block;animation:slide .3s ease}
  .hw-select{width:100%;background:var(--bg);border:1.5px solid transparent;border-radius:14px;
       padding:15px;font:inherit;font-size:15px;font-weight:700;color:var(--ink);cursor:pointer}
  .hw-select:focus{outline:none;background:var(--card);border-color:var(--sky-d)}
  .hw-item{background:var(--bg);border-radius:14px;padding:13px 14px;margin-bottom:9px}
  .hw-top{display:flex;align-items:center;gap:8px;margin-bottom:6px}
  .hw-date{font-size:13px;font-weight:800;color:var(--ink)}
  .hw-tg{font-size:11px;font-weight:700;color:var(--sky-text);background:var(--sky-bg);padding:2px 8px;border-radius:8px}
  .hw-body{font-size:13px;color:var(--ink);font-weight:500;line-height:1.5;white-space:pre-wrap;word-break:break-word}
  .nt-title{font-size:15px;font-weight:800;color:var(--ink);margin-bottom:5px}
  .ao-absent{font-size:13px;color:var(--red);font-weight:600;margin-top:5px;padding-left:2px}
  .pg-bar{height:8px;background:var(--line);border-radius:6px;overflow:hidden;margin-top:8px}
  .pg-bar-fill{height:100%;background:var(--sky-d);border-radius:6px;transition:width .3s}
  .pg-info{font-size:12px;color:var(--gray);font-weight:600;margin-top:6px}
  .season-banner{background:var(--sky-bg);border-radius:14px;padding:13px 15px;margin-bottom:12px}
  .sb-title{font-size:15px;font-weight:800;color:var(--sky-text)}
  .sb-date{font-size:12px;font-weight:600;color:var(--sky-d);margin-top:3px}

  .foot{text-align:center;font-size:12px;color:var(--gray2);margin-top:18px;font-weight:600}
