﻿/* AISFOR clean style.css - 정리본 */

:root{--bg:#07111f;--bg2:#0f172a;--ink:#0f172a;--muted:#64748b;--line:#cbd5e1;--soft:#f8fafc;--card:#ffffff;--blue:#2563eb;--blue2:#1e3a8a;--red:#c1121f;--green:#16a34a;--orange:#f59e0b;--purple:#7c3aed;--radius:6px;--shadow:0 18px 42px rgba(15,23,42,0.12);--shadow-dark:0 26px 70px rgba(0,0,0,0.24)}
*{box-sizing:border-box}
html{min-height:100%;background:var(--bg)}
body{position:relative;min-height:100vh;margin:0;font-family:Arial,'Noto Sans KR',sans-serif;background:radial-gradient(circle at 15% 8%,rgba(59,130,246,0.34),transparent 28%),radial-gradient(circle at 88% 28%,rgba(124,58,237,0.24),transparent 32%),linear-gradient(180deg,#07111f 0%,#0f172a 42%,#111827 100%);color:var(--ink);overflow-x:hidden}
body::before{content:"";position:fixed;inset:0;z-index:0;pointer-events:none;background:linear-gradient(rgba(255,255,255,0.025) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,0.025) 1px,transparent 1px);background-size:38px 38px;mask-image:linear-gradient(180deg,rgba(0,0,0,0.72),transparent 82%)}
a{color:inherit}
button,input,select,textarea{font-family:inherit}

/* 상단 */
.top{position:sticky;top:0;z-index:50;background:radial-gradient(circle at 20% 0%,rgba(59,130,246,0.22),transparent 36%),linear-gradient(135deg,#020617 0%,#08111f 48%,#111827 100%);color:#fff;padding:14px 16px;text-align:left;border-bottom:1px solid rgba(255,255,255,0.10);box-shadow:0 18px 44px rgba(0,0,0,0.28)}
.top::after{content:"";position:absolute;left:0;right:0;bottom:-1px;height:1px;background:linear-gradient(90deg,transparent,rgba(96,165,250,0.7),transparent)}
.top-bar{max-width:760px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:12px}
.top-brand{text-align:center;flex:1}
.logo{display:inline-block;color:#fff;text-decoration:none;font-size:28px;font-weight:900;letter-spacing:1.4px;text-shadow:0 8px 22px rgba(0,0,0,0.25)}
.sub{font-size:13px;color:#cbd5e1;margin-top:3px;font-weight:800}
.menu-toggle-btn{width:44px;height:44px;border:1px solid rgba(255,255,255,0.24);border-radius:var(--radius);background:linear-gradient(145deg,rgba(255,255,255,0.18),rgba(255,255,255,0.08));color:#fff;font-size:25px;font-weight:900;cursor:pointer;box-shadow:0 12px 28px rgba(0,0,0,0.22),inset 0 1px 0 rgba(255,255,255,0.18)}
.menu-toggle-btn:hover{background:rgba(255,255,255,0.22)}
.top-nav{display:none;max-width:760px;margin:12px auto 0;padding:12px;background:#0f172a;border:1px solid rgba(255,255,255,0.12);border-radius:var(--radius);box-shadow:0 12px 26px rgba(15,23,42,0.24)}
.top-nav.open{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}
.home-btn{display:inline-flex;align-items:center;justify-content:center;min-height:42px;text-decoration:none;background:rgba(255,255,255,0.10);color:#fff;border:1px solid rgba(255,255,255,0.18);border-radius:var(--radius);padding:11px 10px;font-size:14px;font-weight:900;cursor:pointer}
.home-btn:hover{background:rgba(255,255,255,0.22)}
.logout-form{display:flex;margin:0}
.logout-form .home-btn{width:100%;font-family:inherit}

/* 공통 레이아웃 */
.page{position:relative;z-index:1;max-width:760px;margin:0 auto;padding:26px 18px 80px;background:transparent}
body:has(.cloud-panel) .page{max-width:1100px}
body:has(.cloud-panel) .top-bar{max-width:1100px}
body:has(.cloud-panel) .top-nav{max-width:1100px}
.page::before{content:"";position:absolute;left:14px;right:14px;top:18px;height:210px;border-radius:var(--radius);background:linear-gradient(135deg,rgba(96,165,250,0.18),rgba(124,58,237,0.12));filter:blur(18px);z-index:-1;pointer-events:none}
.panel,.auth-panel{position:relative;overflow:hidden;background:linear-gradient(145deg,rgba(255,255,255,0.96),rgba(241,245,249,0.88));border:1px solid rgba(219,234,254,0.72);border-radius:var(--radius);box-shadow:var(--shadow-dark),0 8px 24px rgba(59,130,246,0.10),inset 0 1px 0 rgba(255,255,255,0.96)}
.panel{padding:30px 28px;margin-bottom:18px}
.panel::before{content:"";position:absolute;left:-80px;top:-90px;width:220px;height:220px;border-radius:999px;background:radial-gradient(circle,rgba(96,165,250,0.20),transparent 68%);pointer-events:none}
.panel::after{content:"";position:absolute;right:-90px;bottom:-110px;width:240px;height:240px;border-radius:999px;background:radial-gradient(circle,rgba(124,58,237,0.12),transparent 70%);pointer-events:none}
.panel>*{position:relative;z-index:2}
.panel h1,.auth-panel h1{margin:0 0 10px;font-size:34px;font-weight:950;line-height:1.25;letter-spacing:-1.1px;color:#0b1220;text-shadow:0 1px 0 rgba(255,255,255,0.8)}
.panel h1{display:flex;align-items:center;gap:10px}
.panel h2{margin:0 0 14px;font-size:25px;font-weight:950;letter-spacing:-0.6px;color:#0f172a}
.desc{margin:0 0 20px;color:#475569;font-size:17px;font-weight:750;line-height:1.65;word-break:keep-all}

/* 로그인/회원가입 */
.auth-panel{max-width:520px;margin:0 auto;padding:28px}
.auth-form{display:flex;flex-direction:column;gap:14px;margin-top:18px}
.auth-form label{display:flex;flex-direction:column;gap:7px;font-size:15px;font-weight:900;color:#374151}
.auth-form button{border:0;background:var(--blue);color:#fff;border-radius:var(--radius);padding:16px;font-size:20px;font-weight:900;cursor:pointer}
.userid-check-row{display:grid;grid-template-columns:1fr auto;gap:8px;align-items:stretch}
.auth-form .userid-check-btn{min-width:104px;padding:10px 13px;border-radius:var(--radius);background:#1d4ed8;color:#fff;font-size:15px;font-weight:950;white-space:nowrap}
.auth-form .userid-check-btn:disabled{opacity:.65;cursor:wait}
.userid-check-result{display:block;color:#64748b;font-size:13px;font-weight:800;line-height:1.4}
.userid-check-result.success{color:#15803d}
.userid-check-result.error{color:#dc2626}
.auth-link{margin-top:18px;text-align:center;color:#6b7280}
.auth-link a{color:var(--blue);font-weight:900;text-decoration:none}
.login-conflict-box{background:#fff7ed;color:#9a3412;border:1px solid #fed7aa;border-radius:var(--radius);padding:16px;font-size:18px;line-height:1.6;font-weight:900;margin:18px 0}
.remember-row{display:flex!important;flex-direction:row!important;align-items:center!important;gap:9px!important;font-size:15px!important;font-weight:800!important;color:#374151!important}
.remember-row input{width:18px!important;height:18px!important;margin:0!important}
.remember-row span{line-height:1}
.remember-warning{margin:-6px 0 4px;color:#ef4444;font-size:13px;line-height:1.45;font-weight:800}
.secure-unlock-panel{border-color:#fecaca}
.secure-unlock-guide{margin-top:14px;background:#fffbeb;color:#92400e;border:1px solid #fde68a;border-radius:var(--radius);padding:13px;font-size:14px;font-weight:900;line-height:1.45;text-align:center}

/* 홈 히어로 */
.hero{position:relative;overflow:hidden;color:#fff;border-radius:var(--radius);padding:22px 24px 24px;text-align:left;box-shadow:0 24px 58px rgba(193,18,31,0.30),0 8px 22px rgba(127,29,29,0.20),inset 0 1px 0 rgba(255,255,255,0.16)}
.hero-pro.hero-slim{background:#c1121f!important;border:1px solid rgba(255,255,255,0.20)}
.hero-pro.hero-slim::before{content:"";position:absolute;inset:0;background:none!important;pointer-events:none}
.hero-glow{display:none!important}
.hero-badge,.hero-pro .hero-badge{position:relative;display:inline-flex;margin:0 0 10px;background:rgba(255,255,255,0.14);border:1px solid rgba(255,255,255,0.24);border-radius:var(--radius);padding:7px 11px;font-size:13px;font-weight:900;color:#fff}
.hero h1,.hero-pro h1{position:relative;margin:6px 0 10px;font-size:32px;line-height:1.15;letter-spacing:-1.2px;color:#fff;text-shadow:none}
.hero p,.hero-pro p{position:relative;margin:0;max-width:100%;font-size:15px;line-height:1.55;font-weight:800;color:#fff}
.hero-topline,.hero-mini-actions{display:none}

/* 다가오는 일정 */
.section-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px}
.section-head h2{margin:0;font-size:26px;line-height:1.25}
.small-link-btn{display:inline-flex;align-items:center;justify-content:center;text-decoration:none;background:#111827;color:#fff;border-radius:var(--radius);padding:9px 12px;font-size:14px;font-weight:900;white-space:nowrap;box-shadow:0 12px 24px rgba(15,23,42,0.12)}
.upcoming-panel{margin-top:18px;padding:24px!important;border-radius:var(--radius)}
.upcoming-list{display:flex;flex-direction:column;gap:12px}
.upcoming-list-compact{margin-bottom:10px}
.upcoming-item{position:relative;display:flex;align-items:flex-start;gap:12px;text-decoration:none;background:linear-gradient(180deg,#ffffff,#f8fafc);color:#111827;border:1px solid #e5e7eb;border-left:0;border-radius:var(--radius);padding:14px;box-shadow:0 8px 22px rgba(15,23,42,0.06)}
.upcoming-item.private{background:linear-gradient(180deg,#fff,#fffbeb)}
.upcoming-item.secret{background:linear-gradient(180deg,#fff,#fef2f2)}
.upcoming-item::before{content:"";position:absolute;left:0;top:14px;bottom:14px;width:5px;border-radius:var(--radius);background:#9ca3af}
.upcoming-item.private::before{background:#f59e0b}
.upcoming-item.secret::before{background:#ef4444}
.upcoming-dday{flex:0 0 58px;width:58px;min-width:58px;height:58px;display:inline-flex;align-items:center;justify-content:center;background:#111827;color:#fff;border-radius:var(--radius);font-size:15px;font-weight:900;letter-spacing:-0.3px}
.upcoming-body{flex:1;min-width:0}
.upcoming-meta{display:flex;align-items:center;flex-wrap:wrap;gap:6px;margin-bottom:7px}
.upcoming-meta span{display:inline-flex;align-items:center;background:#eef2ff;color:#3730a3;border-radius:var(--radius);padding:5px 9px;font-size:12px;font-weight:900;line-height:1}
.upcoming-count-badge{display:inline-flex;align-items:center;justify-content:center;height:34px;padding:0 10px;border-radius:8px;background:#ecfdf5;color:#047857;border:1px solid #a7f3d0;font-size:12px;font-weight:950;white-space:nowrap}
.upcoming-content{font-size:17px;line-height:1.45;font-weight:900;color:#111827;display:-webkit-box;line-clamp:2;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;word-break:keep-all;overflow-wrap:break-word}
.upcoming-dropdown{margin-top:10px}
.upcoming-dropdown summary{display:flex;align-items:center;justify-content:center;cursor:pointer;background:#f3f4f6;color:#111827;border:1px solid #e5e7eb;border-radius:var(--radius);padding:13px 14px;font-size:15px;font-weight:900;list-style:none}
.upcoming-dropdown summary::-webkit-details-marker{display:none}
.upcoming-dropdown summary::after{content:" 펼치기";margin-left:6px;color:var(--blue);font-size:13px;font-weight:900}
.upcoming-dropdown[open] summary{margin-bottom:12px;background:#eef2ff;border-color:#c7d2fe}
.upcoming-dropdown[open] summary::after{content:" 접기"}
.upcoming-empty{display:grid;gap:5px;padding:16px;border:1px dashed #cbd5e1;border-radius:var(--radius);background:rgba(248,250,252,.92);color:#334155}
.upcoming-empty strong{font-size:17px;font-weight:950;color:#0f172a}
.upcoming-empty span{font-size:14px;font-weight:800;line-height:1.4;color:#64748b}

/* 홈 버튼 */
.big-menu{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin-top:24px;position:relative}
.home-menu-drawer{margin:14px 0 34px}
.home-menu-drawer summary{list-style:none;display:flex;align-items:center;justify-content:space-between;gap:12px;min-height:58px;padding:0 18px;border:1px solid rgba(191,219,254,.72);border-radius:18px;background:linear-gradient(135deg,rgba(248,250,252,.97),rgba(226,232,240,.92));box-shadow:0 18px 38px rgba(15,23,42,.22);color:#0f172a;font-size:22px;font-weight:950;cursor:pointer;user-select:none}
.home-menu-drawer summary::-webkit-details-marker{display:none}
.home-menu-drawer summary b{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:999px;background:#0f172a;color:#fff;font-size:24px;line-height:1;transition:transform .22s ease}
.home-menu-drawer[open] summary b{transform:rotate(180deg)}
.home-menu-drawer .big-menu{margin-top:12px;animation:homeMenuDrop .22s ease both}
@keyframes homeMenuDrop{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}
.big-btn{position:relative;display:grid;grid-template-columns:56px 1fr 16px;align-items:center;gap:12px;min-height:92px;padding:16px;border-radius:var(--radius);background:linear-gradient(145deg,rgba(255,255,255,0.98),rgba(248,250,252,0.92));color:#0f172a;text-decoration:none;border:1px solid rgba(203,213,225,0.75);box-shadow:0 18px 38px rgba(15,23,42,0.10),inset 0 1px 0 rgba(255,255,255,0.95);overflow:hidden;transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease}
.big-btn::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 18% 12%,rgba(96,165,250,0.18),transparent 32%),linear-gradient(135deg,rgba(255,255,255,0.34),transparent 45%);pointer-events:none}
.big-btn::after{content:"›";position:relative;z-index:2;display:flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:var(--radius);color:var(--blue);font-size:25px;font-weight:900;line-height:1}
.big-btn:hover{transform:translateY(-3px);box-shadow:0 24px 46px rgba(15,23,42,0.16),inset 0 1px 0 rgba(255,255,255,1);border-color:rgba(96,165,250,0.75)}
.big-btn>span{position:relative;z-index:2;display:flex;align-items:center;justify-content:center;width:52px;height:52px;border-radius:var(--radius);background:linear-gradient(145deg,#eff6ff,#dbeafe);box-shadow:inset 0 1px 0 rgba(255,255,255,0.92),0 10px 22px rgba(37,99,235,0.18);font-size:27px;line-height:1}
.big-btn strong{position:relative;z-index:2;font-size:17px;font-weight:950;letter-spacing:-0.7px;line-height:1.28;text-align:left;color:#0f172a;word-break:keep-all;overflow-wrap:normal}
.big-btn small{display:none}
.big-btn.primary{border-color:rgba(99,102,241,0.48)}
.big-btn.primary>span{background:linear-gradient(145deg,#eef2ff,#c7d2fe)}
.big-btn.record{border-color:rgba(168,85,247,0.42)}
.big-btn.record>span{background:linear-gradient(145deg,#faf5ff,#e9d5ff)}
.big-btn.danger{border-color:rgba(245,158,11,0.42)}
.big-btn.danger>span{background:linear-gradient(145deg,#fff7ed,#fed7aa)}
.big-btn.game{border-color:rgba(249,115,22,0.48)}
.big-btn.game>span{background:linear-gradient(145deg,#fff7ed,#fdba74)}
.big-btn:nth-child(5)>span{background:linear-gradient(145deg,#eff6ff,#bfdbfe)}
.big-btn:nth-child(7)>span{background:linear-gradient(145deg,#ecfeff,#ccfbf1)}
.big-btn:nth-child(9){min-height:92px}
.big-btn:nth-child(9)>span{background:linear-gradient(145deg,#fff1f2,#fecdd3)}
.big-btn strong .menu-line{display:inline!important;width:auto!important;height:auto!important;min-width:0!important;min-height:0!important;padding:0!important;margin:0!important;border-radius:0!important;background:none!important;box-shadow:none!important;font-size:inherit!important;line-height:inherit!important;color:inherit!important;white-space:normal!important}
.big-btn strong .menu-line+.menu-line::before{content:" "}

/* 음성/녹음 */
.voice-box,.record-box{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px;margin:22px 0 18px;padding:14px;border-radius:var(--radius);background:linear-gradient(145deg,rgba(255,255,255,0.66),rgba(239,246,255,0.56));border:1px solid rgba(191,219,254,0.72);box-shadow:inset 0 1px 0 rgba(255,255,255,0.85),0 18px 36px rgba(15,23,42,0.06)}
.voice-box-multi{align-items:stretch}
.voice-btn{position:relative;min-height:64px;border:0;border-radius:var(--radius);padding:16px 18px;font-size:20px;font-weight:950;letter-spacing:-0.4px;color:#fff;background:linear-gradient(135deg,var(--blue),#4f46e5);box-shadow:0 14px 28px rgba(37,99,235,0.28),inset 0 1px 0 rgba(255,255,255,0.22);cursor:pointer;overflow:hidden;transition:transform .16s ease,box-shadow .16s ease}
.voice-btn::before{content:"";position:absolute;inset:0;background:linear-gradient(120deg,rgba(255,255,255,0.22),transparent 42%);pointer-events:none}
.voice-btn:hover{transform:translateY(-2px);box-shadow:0 18px 34px rgba(37,99,235,0.34),inset 0 1px 0 rgba(255,255,255,0.28)}
.voice-btn.stop{background:linear-gradient(135deg,#059669,#16a34a);box-shadow:0 14px 28px rgba(5,150,105,0.24),inset 0 1px 0 rgba(255,255,255,0.22)}
.voice-btn.english{background:linear-gradient(135deg,#0284c7,#0f766e);box-shadow:0 14px 28px rgba(2,132,199,0.24),inset 0 1px 0 rgba(255,255,255,0.22)}
.voice-btn.cancel{background:linear-gradient(135deg,#334155,#0f172a);box-shadow:0 14px 28px rgba(15,23,42,0.24),inset 0 1px 0 rgba(255,255,255,0.18)}
.voice-btn:disabled{opacity:.55;cursor:not-allowed;transform:none}
.voice-status{grid-column:1/-1;display:flex;align-items:center;justify-content:center;min-height:42px;border-radius:var(--radius);background:linear-gradient(180deg,#fff,#f8fafc);color:#475569;font-size:15px;font-weight:900;border:1px solid rgba(226,232,240,0.95);box-shadow:inset 0 1px 0 rgba(255,255,255,0.95),0 8px 18px rgba(15,23,42,0.04)}
.voice-guide,.date-option-guide{color:#64748b;font-size:14px;line-height:1.65;font-weight:750;word-break:keep-all}
.memo-voice-correction-box{margin:14px 0 18px;padding:14px;border:1px solid #93c5fd;border-radius:var(--radius);background:linear-gradient(145deg,#eff6ff,#ffffff);box-shadow:0 14px 28px rgba(37,99,235,.10)}
.memo-voice-correction-box[hidden]{display:none}
.memo-voice-correction-head{display:flex;flex-direction:column;gap:4px;margin-bottom:11px}
.memo-voice-correction-head strong{color:#1e3a8a;font-size:18px;font-weight:950}
.memo-voice-correction-head span{color:#475569;font-size:13px;font-weight:800;line-height:1.5}
.memo-voice-correction-compare{display:grid;grid-template-columns:1fr 1fr;gap:9px}
.memo-voice-correction-compare div{padding:11px;border:1px solid #dbeafe;border-radius:8px;background:#fff}
.memo-voice-correction-compare b{display:block;margin-bottom:6px;color:#475569;font-size:12px;font-weight:950}
.memo-voice-correction-compare p{margin:0;color:#0f172a;font-size:15px;font-weight:850;line-height:1.58;white-space:pre-wrap;word-break:break-word}
.memo-voice-correction-actions{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;margin-top:11px}
.memo-voice-correction-actions button{min-height:44px;border:0;border-radius:8px;padding:9px 8px;background:#2563eb;color:#fff;font-size:14px;font-weight:950;cursor:pointer}
.memo-voice-correction-actions button:nth-child(2){background:#475569}
.memo-voice-correction-actions button:nth-child(3){background:#0f766e}
.web-voice-save-box{grid-template-columns:1.5fr 1fr 1fr}
.web-voice-command-input{grid-column:1/-1;width:100%;border:1px solid #bfdbfe;border-radius:var(--radius);background:#fff;padding:14px 15px;color:#0f172a;font-size:16px;font-weight:800;outline:none}
.web-voice-command-input:focus{border-color:#60a5fa;box-shadow:0 0 0 4px rgba(96,165,250,0.18)}
.web-voice-guide{grid-column:1/-1;margin:0;padding:2px 3px;color:#475569;font-size:13px;font-weight:800;line-height:1.65}
.web-voice-correction-grid{display:grid;grid-template-columns:1fr 1fr;gap:9px}
.web-voice-correction-grid div{padding:11px;border:1px solid #dbeafe;border-radius:8px;background:#fff}
.web-voice-correction-grid b{display:block;margin-bottom:6px;color:#475569;font-size:12px;font-weight:950}
.web-voice-correction-grid p{margin:0;color:#0f172a;font-size:15px;font-weight:850;line-height:1.58;white-space:pre-wrap;word-break:break-word}
.audio-preview-box,.record-play-box{background:linear-gradient(145deg,rgba(255,255,255,0.88),rgba(239,246,255,0.72));border:1px solid rgba(191,219,254,0.78);border-radius:var(--radius);padding:14px;margin:14px 0;box-shadow:0 16px 38px rgba(15,23,42,0.08),inset 0 1px 0 rgba(255,255,255,0.90)}
.audio-preview-box strong,.record-label{display:block;margin:0 0 8px;font-size:15px;font-weight:900;color:#374151}
.audio-preview-box audio,.record-play-box audio{width:100%}
.record-mode-box,.meeting-info-box{margin:18px 0;background:linear-gradient(145deg,rgba(255,255,255,0.88),rgba(241,245,249,0.68));border:1px solid rgba(191,219,254,0.88);border-radius:var(--radius);padding:16px;box-shadow:0 16px 34px rgba(15,23,42,0.07),inset 0 1px 0 rgba(255,255,255,0.9)}
.record-mode-box label{display:flex;flex-direction:column;gap:8px;font-size:15px;font-weight:900;color:#374151;margin-bottom:12px}
.broadcast-guide-box{margin:14px 0 0;border:1px solid #93c5fd;border-radius:var(--radius);background:linear-gradient(145deg,#eff6ff,#ffffff);padding:14px;color:#1e3a8a;box-shadow:0 12px 24px rgba(37,99,235,.08)}
.broadcast-guide-box strong{display:block;margin-bottom:8px;font-size:16px;font-weight:950}
.broadcast-guide-box ol{margin:0;padding-left:21px;color:#334155;font-size:14px;font-weight:800;line-height:1.65}

/* 입력 폼 */
.form-box{margin-top:18px}
.form-box textarea,.form-box input[type="text"],.form-box input[type="url"],.form-box input[type="date"],.form-box input[type="datetime-local"],.form-box input[type="password"],.form-box select,.auth-form input,.link-option-box input[type="text"],.link-option-box input[type="url"],.link-option-box select,.category-option-box select,.date-option-box input[type="date"],.date-option-box input[type="datetime-local"],.record-mode-box select,.record-mode-box input[type="text"],.record-mode-box textarea{width:100%;border:1px solid rgba(148,163,184,0.58);border-radius:var(--radius);background:linear-gradient(180deg,#ffffff,#f8fbff);padding:17px 18px;font-size:18px;color:#0f172a;box-shadow:inset 0 1px 0 rgba(255,255,255,0.96),0 12px 26px rgba(15,23,42,0.055);outline:none;transition:border-color .16s ease,box-shadow .16s ease,background .16s ease}
.form-box textarea:focus,.form-box input:focus,.form-box select:focus,.auth-form input:focus,.link-option-box input:focus,.link-option-box select:focus,.category-option-box select:focus,.date-option-box input:focus,.record-mode-box select:focus,.record-mode-box input:focus,.record-mode-box textarea:focus{border-color:#60a5fa;box-shadow:0 0 0 4px rgba(96,165,250,0.18),0 14px 28px rgba(15,23,42,0.08);background:#fff}
.form-box textarea{min-height:230px;line-height:1.72;resize:vertical}
.form-box label,.category-option-box label,.date-option-box label,.image-option-box label,.link-option-box label{display:flex;flex-direction:column;gap:7px;font-size:15px;font-weight:950;color:#334155;letter-spacing:-0.2px;margin-bottom:10px}
.category-option-box,.date-option-box,.image-option-box,.link-option-box{margin:14px 0 4px;background:linear-gradient(145deg,rgba(255,255,255,0.88),rgba(241,245,249,0.68));border:1px solid rgba(191,219,254,0.88);border-radius:var(--radius);padding:18px;box-shadow:0 16px 34px rgba(15,23,42,0.07),inset 0 1px 0 rgba(255,255,255,0.9)}
.submit-btn{position:relative;width:100%;min-height:66px;margin-top:18px;border:0;border-radius:var(--radius);background:linear-gradient(135deg,#0f172a,#1e3a8a 52%,#2563eb);color:#fff;font-size:22px;font-weight:950;letter-spacing:-0.5px;box-shadow:0 18px 38px rgba(30,58,138,0.28),inset 0 1px 0 rgba(255,255,255,0.2);cursor:pointer;overflow:hidden;transition:transform .16s ease,box-shadow .16s ease}
.submit-btn:hover{transform:translateY(-2px);box-shadow:0 22px 44px rgba(30,58,138,0.34),inset 0 1px 0 rgba(255,255,255,0.26)}
.result-box{margin-top:18px}
.success,.error,.empty{border-radius:var(--radius);padding:18px 19px;font-size:17px;line-height:1.65;font-weight:800;box-shadow:0 12px 26px rgba(15,23,42,0.06)}
.success{background:linear-gradient(145deg,#ecfdf5,#fff);border:1px solid #a7f3d0;color:#065f46}
.error{background:linear-gradient(145deg,#fef2f2,#fff);border:1px solid #fecaca;color:#991b1b}
.empty{background:linear-gradient(145deg,#f8fafc,#fff);border:1px solid #e2e8f0;color:#64748b}
.dday-check-row{display:flex!important;flex-direction:row!important;align-items:center!important;gap:9px!important;margin-bottom:6px!important}
.dday-check-row input{width:18px!important;height:18px!important;margin:0!important}
.dday-check-row span{line-height:1.4}
.image-option-box input[type="file"]{width:100%;border:2px dashed #bfdbfe;border-radius:var(--radius);padding:13px;font-size:16px;background:#fff}
.image-clear-btn{margin-top:10px;border:0;background:#dc2626;color:#fff;border-radius:var(--radius);padding:9px 14px;font-size:14px;font-weight:900;cursor:pointer}
.handwriting-box{margin:14px 0}
.handwriting-toggle-btn{width:100%;min-height:54px;border:1px solid #93c5fd;border-radius:var(--radius);background:linear-gradient(135deg,#eff6ff,#dbeafe);color:#1e3a8a;font-size:17px;font-weight:950;cursor:pointer;box-shadow:0 12px 24px rgba(37,99,235,.10)}
.handwriting-panel{margin-top:10px;border:1px solid #bfdbfe;border-radius:var(--radius);background:#eff6ff;padding:12px;box-shadow:0 14px 28px rgba(37,99,235,.10)}
.handwriting-head{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;margin-bottom:10px}
.handwriting-head strong{display:block;color:#1e3a8a;font-size:17px;font-weight:950}
.handwriting-head small{display:block;margin-top:4px;color:#475569;font-size:12px;font-weight:800;line-height:1.45}
.handwriting-clear-btn{flex-shrink:0;border:0;border-radius:var(--radius);background:#dc2626;color:#fff;padding:9px 11px;font-size:13px;font-weight:950;cursor:pointer}
#handwritingCanvas{display:block;width:100%;height:auto;aspect-ratio:900/520;border:2px solid #93c5fd;border-radius:var(--radius);background:#fff;touch-action:none;cursor:crosshair;box-shadow:inset 0 2px 8px rgba(15,23,42,.08)}
.handwriting-status{margin:8px 0 0;color:#475569;font-size:13px;font-weight:850}

/* 검색 */
.search-box{display:grid;grid-template-columns:1fr auto;gap:10px}
.search-box input{border:1px solid #cbd5e1;border-radius:var(--radius);background:#fff;padding:16px 18px;font-size:18px;box-shadow:0 10px 22px rgba(15,23,42,0.05)}
.search-box button{border:0;border-radius:var(--radius);background:linear-gradient(135deg,#0f172a,#2563eb);color:#fff;padding:0 24px;font-size:18px;font-weight:950;box-shadow:0 14px 28px rgba(37,99,235,0.24);cursor:pointer}
.search-box-wrap{flex-wrap:wrap;align-items:center}
.secure-search-row{display:inline-flex;align-items:center;gap:8px;background:linear-gradient(145deg,#fff7ed,#fff);color:#9a3412;border:1px solid #fed7aa;border-radius:var(--radius);padding:11px 13px;font-size:14px;font-weight:950;white-space:nowrap}
.secure-search-row input{width:17px;height:17px;margin:0}

/* 메모/목록 */
.memo-list{display:flex;flex-direction:column;gap:12px}
.memo-card{position:relative;overflow:hidden;background:linear-gradient(145deg,#fff,#f8fafc);border:1px solid rgba(226,232,240,0.95);border-left:0;border-radius:var(--radius);padding:18px;box-shadow:0 14px 34px rgba(15,23,42,0.08)}
.memo-card::before{content:"";position:absolute;left:0;top:18px;bottom:18px;width:5px;border-radius:var(--radius);background:#94a3b8}
.memo-card.private::before{background:#f59e0b}
.memo-card.secret::before{background:#ef4444}
.memo-meta{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:10px}
.memo-meta span{background:#eef2ff;color:#3730a3;border-radius:var(--radius);padding:7px 11px;font-size:12px;font-weight:950}
.level-secret{background:#fee2e2!important;color:#991b1b!important}
.level-private{background:#fef3c7!important;color:#92400e!important}
.dday-badge{background:#111827!important;color:#fff!important;font-weight:900}
.reminder-badge{display:inline-flex!important;align-items:center!important;border-radius:999px!important;background:#dcfce7!important;color:#166534!important;padding:6px 10px!important;font-size:12px!important;font-weight:950!important;line-height:1!important;white-space:nowrap!important}
.memo-reminder-row{display:flex;flex-wrap:wrap;gap:7px;margin:0 0 10px}
.memo-content{font-size:18px;line-height:1.72;color:#0f172a;white-space:pre-wrap}
.command-option-box{margin:14px 0;padding:14px;border-radius:var(--radius);background:#f8fafc;border:1px solid #e2e8f0}
.command-option-box label{display:block;font-weight:900;color:#0f172a}
.command-option-box textarea{margin-top:8px}
.memo-command-list{display:flex;flex-wrap:wrap;gap:6px;margin-top:12px}
.memo-command-list span{display:inline-flex;align-items:center;max-width:100%;padding:5px 9px;border-radius:999px;background:#eff6ff;border:1px solid #bfdbfe;color:#1d4ed8;font-size:13px;font-weight:850;word-break:break-all}
.memo-actions{display:flex;justify-content:flex-end;gap:9px;margin-top:16px}
.edit-btn,.delete-btn,.open-link-btn,.download-doc-btn,.share-doc-btn,.print-doc-btn{display:inline-flex;align-items:center;justify-content:center;text-decoration:none;border:0;border-radius:var(--radius);padding:10px 14px;font-size:14px;font-weight:950;color:#fff;box-shadow:0 10px 20px rgba(15,23,42,0.10);cursor:pointer}
.edit-btn{background:linear-gradient(135deg,#2563eb,#4f46e5)}
.delete-btn{background:linear-gradient(135deg,#ef4444,#b91c1c)}
.open-link-btn{background:linear-gradient(135deg,#0f766e,#14b8a6)}
.print-doc-btn{background:linear-gradient(135deg,#0f172a,#334155)}
.download-doc-btn{background:linear-gradient(135deg,#4f46e5,#7c3aed)}
.share-doc-btn{background:linear-gradient(135deg,#0891b2,#0f766e)}
.back-actions{margin-top:20px}
.back-btn{display:inline-flex;align-items:center;justify-content:center;min-height:46px;text-decoration:none;background:linear-gradient(145deg,#fff,#f8fafc);color:#334155;border:1px solid #cbd5e1;border-radius:var(--radius);padding:11px 16px;font-size:15px;font-weight:950;box-shadow:0 10px 22px rgba(15,23,42,0.06)}

/* 필터 */
.filter-menu{display:flex;flex-wrap:wrap;gap:9px;margin:20px 0}
.filter-menu a{display:inline-flex;align-items:center;justify-content:center;text-decoration:none;background:linear-gradient(145deg,#fff,#f8fafc);border:1px solid #dbeafe;color:#334155;border-radius:var(--radius);padding:11px 15px;font-size:14px;font-weight:950;box-shadow:0 8px 18px rgba(15,23,42,0.05)}
.filter-menu a.on{background:linear-gradient(135deg,#0f172a,#1e3a8a);color:#fff;border-color:#1e3a8a}
.filter-menu a.danger{background:linear-gradient(135deg,#fff7ed,#fff);color:#9a3412;border-color:#fed7aa}
.filter-menu a.danger.on{background:linear-gradient(135deg,#f97316,#dc2626);color:#fff;border-color:#f97316}

/* 웹링크/이미지 */
.link-preview-box,.memo-image-preview-box,.memo-image-box{margin-top:12px;background:linear-gradient(145deg,#eff6ff,#fff);border:1px solid #bfdbfe;border-radius:var(--radius);padding:12px;box-shadow:0 12px 26px rgba(37,99,235,0.07)}
.link-preview-title{font-size:16px;font-weight:900;color:#1e3a8a;margin-bottom:5px}
.link-preview-group{font-size:12px;font-weight:900;color:#475569;margin-bottom:4px}
.link-preview-url{font-size:13px;font-weight:800;color:#2563eb;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.memo-image-preview-box strong,.memo-image-edit-box strong{display:block;margin-bottom:8px;font-size:15px;color:#1e3a8a}
.memo-image-preview-box img,.memo-image-box img,.memo-image-preview-box video,.memo-image-box video{display:block;width:100%;max-height:420px;object-fit:contain;border-radius:var(--radius);background:#000}
.memo-media-preview-list{display:grid;grid-template-columns:1fr;gap:6px;margin-top:10px}
.memo-media-preview-item{border:1px solid #dbeafe;border-radius:8px;background:#fff;padding:8px 10px;color:#334155;font-size:14px;font-weight:850;word-break:break-all}

/* 달력 */
.calendar-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:8px}
.calendar-head h1{text-align:center;margin:0}
.cal-nav-btn{display:inline-flex;align-items:center;justify-content:center;text-decoration:none;background:#111827;color:#fff;border-radius:var(--radius);padding:10px 14px;font-size:14px;font-weight:900;white-space:nowrap;box-shadow:0 12px 24px rgba(15,23,42,0.12)}
.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:8px}
.calendar-week{margin-top:18px;margin-bottom:8px}
.calendar-week div{text-align:center;font-weight:900;color:#374151;background:#f3f4f6;border-radius:var(--radius);padding:10px 0}
.calendar-week .sun{color:#dc2626}
.calendar-week .sat{color:#2563eb}
.calendar-cell{min-height:120px;background:#fff;border:1px solid #e5e7eb;border-radius:var(--radius);padding:10px}
.calendar-cell.today{border-color:#2563eb;box-shadow:0 0 0 2px rgba(37,99,235,0.15)}
.calendar-cell.sunday .calendar-date,.calendar-cell.holiday .calendar-date{color:#dc2626}
.calendar-cell.saturday .calendar-date{color:#2563eb}
.empty-cell{background:transparent;border:0}
.calendar-date{font-size:16px;font-weight:900;margin-bottom:8px;color:#111827}
.calendar-item{display:block;text-decoration:none;background:#f3f4f6;color:#111827;border-left:4px solid #9ca3af;border-radius:var(--radius);padding:7px 8px;margin-top:6px;font-size:12px;line-height:1.35}
.calendar-item.private{border-left-color:#f59e0b}
.calendar-item.secret{border-left-color:#ef4444}
.calendar-item span{display:block;font-size:11px;color:#6b7280;margin-bottom:2px}
.calendar-item strong{display:block;font-weight:800}
.calendar-mark{display:block;margin-top:4px;padding:3px 5px;border-radius:var(--radius);font-size:11px;font-weight:900;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.calendar-mark.holiday{background:#fee2e2;color:#991b1b}
.calendar-mark.season{background:#ecfdf5;color:#047857}

/* 녹음 처리 상태 */
.record-processing-box{overflow:hidden;border-radius:var(--radius)}
.record-processing-title{font-size:18px;font-weight:900;color:#065f46;margin-bottom:6px}
.record-processing-text{font-size:14px;font-weight:800;color:#047857;line-height:1.45;margin-bottom:12px}
.record-progress{width:100%;height:15px;background:#d1fae5;border-radius:var(--radius);overflow:hidden;position:relative}
.record-progress-bar{width:38%;height:100%;background:linear-gradient(90deg,#10b981,#34d399,#10b981);border-radius:var(--radius);position:absolute;left:-40%;top:0;animation:recordProgressMove 1.25s infinite ease-in-out}
.record-processing-step{margin-top:10px;font-size:13px;font-weight:900;color:#065f46}
.record-segment-log{margin-top:12px;display:flex;flex-direction:column;gap:6px}
.record-segment-item{background:#f8fafc;border:1px solid #d1fae5;border-radius:var(--radius);padding:8px 10px;font-size:13px;font-weight:900;color:#065f46}
.record-segment-item.working{background:#eff6ff;border-color:#bfdbfe;color:#1e3a8a}
.record-segment-item.done{background:#ecfdf5;border-color:#86efac;color:#166534}
.record-segment-item.warn{background:#fffbeb;border-color:#fde68a;color:#92400e}
.record-segment-item.error{background:#fef2f2;border-color:#fecaca;color:#991b1b}
@keyframes recordProgressMove{0%{left:-40%}50%{left:45%}100%{left:100%}}
.record-quality-box{margin:0 0 18px;padding:15px;border:1px solid #bfdbfe;border-radius:var(--radius);background:linear-gradient(145deg,#eff6ff,#fff);box-shadow:0 14px 28px rgba(37,99,235,.08)}
.record-quality-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:11px;color:#1e3a8a;font-size:16px;font-weight:950}
.record-quality-badge{display:inline-flex;align-items:center;min-height:28px;padding:5px 10px;border-radius:999px;background:#e2e8f0;color:#475569;font-size:12px;font-weight:950}
.record-quality-badge.good{background:#dcfce7;color:#166534}.record-quality-badge.warn{background:#fef3c7;color:#92400e}.record-quality-badge.bad{background:#fee2e2;color:#991b1b}
.record-level-track{height:18px;overflow:hidden;border-radius:999px;background:#dbeafe;box-shadow:inset 0 1px 3px rgba(15,23,42,.12)}
.record-level-bar{width:0;height:100%;border-radius:inherit;background:#94a3b8;transition:width .12s ease,background .12s ease}.record-level-bar.good{background:linear-gradient(90deg,#22c55e,#16a34a)}.record-level-bar.quiet{background:#f59e0b}.record-level-bar.bad{background:#ef4444}
.record-quality-meta{display:flex;justify-content:space-between;gap:8px;margin-top:10px;color:#334155;font-size:13px;font-weight:850;line-height:1.45}
.record-quality-guide{margin:9px 0 0;color:#64748b;font-size:13px;font-weight:750;line-height:1.55}
.record-quality-list-row{display:flex;align-items:center;gap:9px;margin:10px 0;padding:10px;border-radius:var(--radius);background:#f8fafc;color:#475569;font-size:13px;font-weight:800;line-height:1.45}

/* 모바일 */
@media(max-width:700px){.top{padding:12px}.top-bar{align-items:center}.top-brand{text-align:left}.logo{font-size:25px}.sub{font-size:12px}.top-nav.open{grid-template-columns:repeat(2,1fr)}.home-btn{font-size:13px;padding:11px 8px}.page{padding:22px 14px 78px}.page::before{left:10px;right:10px;top:12px;height:190px}.panel{padding:24px 22px}.panel h1{font-size:28px}.desc{font-size:15px;line-height:1.58}.hero{padding:20px 20px 22px}.hero-badge{font-size:12px;margin-bottom:9px}.hero h1{font-size:29px}.hero p{font-size:14px;line-height:1.5}.upcoming-panel{padding:22px!important}.section-head{align-items:center;margin-bottom:14px}.section-head h2{font-size:24px}.small-link-btn{font-size:13px;padding:8px 11px}.upcoming-item{flex-direction:row;gap:10px;padding:13px 12px 13px 15px}.upcoming-dday{width:52px;min-width:52px;height:52px;flex-basis:52px;font-size:14px}.upcoming-meta span{font-size:11px;padding:4px 8px}.upcoming-content{font-size:16px;line-height:1.4}.big-menu{grid-template-columns:repeat(2,1fr);gap:12px;margin-top:22px}.big-btn{grid-template-columns:54px 1fr 14px;gap:11px;min-height:86px;padding:14px 13px}.big-btn>span{width:52px;height:52px;font-size:28px}.big-btn strong{font-size:15px;line-height:1.28}.big-btn.danger strong{font-size:15px}.big-btn::after{font-size:25px;width:18px;height:18px}.big-btn:nth-child(9){min-height:86px}.big-btn strong .menu-line{display:block!important;white-space:nowrap!important}.big-btn strong .menu-line+.menu-line::before{content:""}.voice-box,.record-box{grid-template-columns:1fr;gap:11px;padding:12px}.voice-btn{width:100%;min-height:68px;font-size:21px}.voice-status{min-height:40px;font-size:14px;text-align:center}.form-box textarea{min-height:260px;font-size:18px}.memo-voice-correction-compare,.memo-voice-correction-actions,.web-voice-correction-grid{grid-template-columns:1fr}.memo-voice-correction-actions button{min-height:48px}.submit-btn{min-height:66px;font-size:21px}.search-box{grid-template-columns:1fr}.search-box button{min-height:56px;padding:14px 18px}.secure-search-row{justify-content:center;width:100%}.memo-actions{flex-wrap:wrap}.memo-actions button,.memo-actions a{flex:1 1 calc(50% - 9px);min-height:42px}.calendar-head{flex-direction:column}.calendar-grid{gap:4px}.calendar-cell{min-height:86px;padding:5px;overflow:hidden}.calendar-cell.empty-cell{display:block;background:transparent;border:0}.calendar-week div{font-size:13px;padding:8px 0}.calendar-date{font-size:15px;margin-bottom:4px;line-height:1}.calendar-item{width:100%;font-size:10px;line-height:1.2;padding:3px 4px;margin-top:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.calendar-item span{display:none}.calendar-item strong{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.calendar-mark{font-size:9px;padding:2px 3px;margin-top:2px}.calendar-cell.holiday,.calendar-cell.sunday{background:#fff7f7}}
@media(max-width:380px){.big-btn{grid-template-columns:48px 1fr 12px;gap:9px;padding:13px 11px}.big-btn>span{width:46px;height:46px;font-size:25px}.big-btn strong{font-size:14px}.big-btn.danger strong{font-size:13px}}
@media print{@page{size:A4;margin:18mm 16mm 20mm 16mm}}

.reminder-check-group{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:10px;
  margin:10px 0 8px;
}

.reminder-check-group .dday-check-row{
  background:#ffffff;
  border:1px solid rgba(203,213,225,0.85);
  padding:10px 12px;
}
.exact-reminder-box{margin-top:10px!important;border:1px solid #86efac;border-radius:var(--radius);background:#f0fdf4;padding:12px}
.exact-reminder-box span{color:#166534;font-size:14px;font-weight:950}
.exact-reminder-box small{color:#047857;font-size:12px;font-weight:800;line-height:1.45}

@media(max-width:700px){
  .reminder-check-group{
    grid-template-columns:1fr;
  }
}

/* 관리자 회원관리 - PC 리스트 / 모바일 카드 */
.admin-page-panel{width:min(1420px,calc(100vw - 56px));margin-left:50%;transform:translateX(-50%)}
.admin-user-card-list{display:none}
.admin-user-table-wrap{width:100%;overflow-x:auto;border:1px solid #dbeafe;border-radius:var(--radius);background:#ffffff;box-shadow:0 14px 34px rgba(15,23,42,0.08)}
.admin-user-table{width:100%;min-width:1260px;border-collapse:collapse;background:#ffffff;color:#0f172a;font-size:13px}
.admin-user-table th{position:sticky;top:0;z-index:2;background:#0f172a;color:#ffffff;padding:10px 8px;text-align:center;font-size:13px;font-weight:950;white-space:nowrap;border-bottom:1px solid #1e293b}
.admin-user-table td{padding:9px 8px;border-bottom:1px solid #e5e7eb;vertical-align:middle;background:#ffffff}
.admin-user-table tbody tr:nth-child(even) td{background:#f8fafc}
.admin-user-table tbody tr:hover td{background:#eef2ff}
.admin-user-main-cell strong{display:block;font-size:14px;font-weight:950;color:#111827;line-height:1.25;white-space:nowrap}
.admin-user-main-cell span{display:block;margin-top:3px;font-size:12px;font-weight:850;color:#64748b;white-space:nowrap}
.admin-badge-row{display:flex;justify-content:center;flex-wrap:wrap;gap:4px;min-width:92px}
.admin-mini-badge{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;padding:4px 7px;font-size:11px;font-weight:950;line-height:1;white-space:nowrap;background:#e5e7eb;color:#374151}
.admin-mini-badge.paid{background:#dbeafe;color:#1e40af}
.admin-mini-badge.free{background:#f3f4f6;color:#374151}
.admin-mini-badge.admin{background:#ede9fe;color:#5b21b6}
.admin-mini-badge.user{background:#ecfdf5;color:#047857}
.admin-mini-badge.ok{background:#dcfce7;color:#166534}
.admin-mini-badge.stop{background:#fee2e2;color:#991b1b}
.admin-usage-cell{min-width:160px;color:#334155;font-size:12px;font-weight:850;line-height:1.45}
.admin-usage-cell b{font-weight:950;color:#111827}
.admin-user-table input,.admin-user-table select{width:100%;min-width:82px;border:1px solid #cbd5e1;border-radius:var(--radius);background:#ffffff;padding:8px 7px;font-size:13px;font-weight:850;color:#0f172a;outline:none}
.admin-user-table input[type="date"]{min-width:132px}
.admin-user-table input[type="checkbox"]{width:18px;min-width:18px;height:18px;cursor:pointer}
.admin-check-cell{text-align:center}
.admin-table-save-btn{border:0;border-radius:var(--radius);background:linear-gradient(135deg,#0f172a,#2563eb);color:#ffffff;padding:9px 13px;font-size:13px;font-weight:950;cursor:pointer;white-space:nowrap;box-shadow:0 8px 18px rgba(37,99,235,0.18)}
.admin-table-save-btn:hover{filter:brightness(1.05)}
.admin-user-list{display:flex;flex-direction:column;gap:14px}
.admin-usage-box{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;margin:12px 0;padding:13px;border:1px solid #dbeafe;border-radius:var(--radius);background:#f8fafc;color:#334155;font-size:14px;font-weight:850;line-height:1.45}
.admin-user-form{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-top:12px}
.admin-user-form label{display:flex;flex-direction:column;gap:6px;font-size:13px;font-weight:950;color:#334155}
.admin-user-form input,.admin-user-form select{width:100%;border:1px solid rgba(148,163,184,0.58);border-radius:var(--radius);background:#fff;padding:11px 12px;font-size:15px;color:#0f172a}
.admin-active-row{grid-column:1/-1;margin:0!important;background:#fff7ed;border:1px solid #fed7aa;border-radius:var(--radius);padding:10px!important}
.admin-save-btn{grid-column:1/-1;min-height:48px!important;margin-top:2px!important;font-size:17px!important}
@media(max-width:700px){.admin-page-panel{width:auto;margin-left:0;transform:none}.admin-user-table-wrap{display:none}.admin-user-card-list{display:flex;flex-direction:column;gap:14px}.admin-usage-box{grid-template-columns:1fr}.admin-user-form{grid-template-columns:1fr}}

/* 프로필 수정 */
.profile-panel{max-width:680px;margin-left:auto;margin-right:auto}
.profile-form input[readonly]{background:#f1f5f9;color:#64748b;font-weight:900;cursor:not-allowed}
.profile-nav-provider-box{margin:14px 0 18px;padding:16px;border:1px solid #dbeafe;border-radius:var(--radius);background:#f8fafc}
.profile-nav-provider-box legend{padding:0 6px;font-size:16px;font-weight:950;color:#0f172a}
.profile-nav-provider-box label{display:flex!important;flex-direction:row!important;align-items:center;gap:9px;margin:8px 0!important;font-size:15px!important;color:#334155!important}
.profile-nav-provider-box input[type="radio"]{width:18px;height:18px}
.profile-password-box{margin-top:18px;padding:18px;border:1px solid #dbeafe;border-radius:var(--radius);background:linear-gradient(145deg,#ffffff,#f8fafc);box-shadow:0 12px 26px rgba(15,23,42,0.06)}
.profile-password-box h2{margin:0 0 8px;font-size:22px;font-weight:950;color:#0f172a}
.profile-password-box p{margin:0 0 14px;color:#64748b;font-size:14px;font-weight:800;line-height:1.5}

/* 상단 프로필 사진 */
.top-brand{display:flex;align-items:center;justify-content:center;gap:11px;text-align:left;flex:1}
.top-brand-text{display:flex;flex-direction:column;align-items:flex-start;line-height:1}
.top-profile-photo{width:44px;height:44px;min-width:44px;border-radius:999px;overflow:hidden;display:inline-flex;align-items:center;justify-content:center;text-decoration:none;background:linear-gradient(145deg,#ffffff,#dbeafe);border:2px solid rgba(255,255,255,0.72);box-shadow:0 10px 24px rgba(0,0,0,0.28)}
.top-profile-photo img{width:100%;height:100%;object-fit:cover;display:block}
.top-profile-photo span{font-size:20px;font-weight:950;color:#1e3a8a}

/* 프로필 사진 수정 */
.profile-photo-edit-box{display:flex;align-items:center;gap:16px;margin:0 0 18px;padding:16px;border:1px solid #dbeafe;border-radius:var(--radius);background:linear-gradient(145deg,#ffffff,#f8fafc);box-shadow:0 12px 26px rgba(15,23,42,0.06)}
.profile-photo-preview{width:82px;height:82px;min-width:82px;border-radius:999px;overflow:hidden;display:flex;align-items:center;justify-content:center;background:linear-gradient(145deg,#eff6ff,#dbeafe);border:2px solid #bfdbfe;box-shadow:0 12px 24px rgba(37,99,235,0.16)}
.profile-photo-preview img{width:100%;height:100%;object-fit:cover;display:block}
.profile-photo-preview span{font-size:34px;font-weight:950;color:#1e3a8a}
.profile-photo-edit-box label{flex:1;margin:0!important}
.profile-photo-edit-box input[type="file"]{width:100%;border:2px dashed #bfdbfe;border-radius:var(--radius);padding:12px;background:#fff;font-size:14px;font-weight:800}
.profile-photo-edit-box p{margin:0;color:#64748b;font-size:13px;font-weight:800;line-height:1.45}

@media(max-width:700px){
  .top-brand{justify-content:flex-start}
  .top-profile-photo{width:42px;height:42px;min-width:42px}
  .profile-photo-edit-box{align-items:flex-start;flex-direction:column}
}

/* 홈 빨간 히어로 박스 위아래 여백 축소 */
.hero.hero-pro.hero-slim{margin-top:0;margin-bottom:0}
.big-menu{margin-top:12px}

@media(max-width:700px){
  .page{padding-top:12px}
  .hero{padding-top:16px;padding-bottom:16px}
  .big-menu{margin-top:12px}
}

/* AISFOR 인트로 캐릭터 화면 - 정리본 */
.aisfor-intro-page{position:relative;min-height:100vh;overflow:hidden;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:18px;margin:-26px -18px -80px;padding:36px 18px 30px;background:radial-gradient(circle at 50% 8%,rgba(56,189,248,0.38),transparent 28%),radial-gradient(circle at 18% 78%,rgba(168,85,247,0.28),transparent 32%),radial-gradient(circle at 84% 72%,rgba(34,197,94,0.16),transparent 30%),linear-gradient(160deg,#020617 0%,#07111f 48%,#111827 100%);color:#fff;text-align:center}
.aisfor-intro-page::before{content:"";position:absolute;inset:0;pointer-events:none;background:linear-gradient(rgba(148,163,184,0.055) 1px,transparent 1px),linear-gradient(90deg,rgba(148,163,184,0.045) 1px,transparent 1px);background-size:34px 34px;mask-image:radial-gradient(circle at center,rgba(0,0,0,0.82),transparent 76%)}
.aisfor-intro-page::after{content:"";position:absolute;left:50%;top:48%;width:520px;height:520px;transform:translate(-50%,-50%);border-radius:999px;background:radial-gradient(circle,rgba(56,189,248,0.18),transparent 64%);filter:blur(16px);pointer-events:none;animation:introAuraPulse 3.8s ease-in-out infinite}
.intro-bg-dot{position:absolute;border-radius:999px;filter:blur(2px);opacity:.65;pointer-events:none}
.intro-bg-dot.dot-1{left:10%;top:12%;width:16px;height:16px;background:#93c5fd;animation:introBgFloat 5s ease-in-out infinite}
.intro-bg-dot.dot-2{right:14%;top:28%;width:22px;height:22px;background:#c4b5fd;animation:introBgFloat 6.4s ease-in-out infinite reverse}
.intro-bg-dot.dot-3{left:18%;bottom:18%;width:12px;height:12px;background:#ffffff;animation:introBgFloat 4.6s ease-in-out infinite}
.intro-character-zone{position:relative;width:250px;height:250px;display:flex;align-items:center;justify-content:center}
.intro-character-zone::before{content:"";position:absolute;inset:20px;border-radius:999px;background:conic-gradient(from 0deg,transparent,rgba(56,189,248,0.85),transparent,rgba(168,85,247,0.75),transparent);filter:blur(1px);animation:introOrbitSpin 7s linear infinite}
.intro-character-zone::after{content:"";position:absolute;inset:43px;border-radius:999px;border:1px dashed rgba(191,219,254,0.42);animation:introOrbitSpin 11s linear infinite reverse}
.intro-ring{position:absolute;border-radius:999px;border:1px solid rgba(125,211,252,0.34);box-shadow:0 0 30px rgba(56,189,248,0.22),inset 0 0 22px rgba(59,130,246,0.12);animation:introPulse 2.8s ease-out infinite}
.intro-ring.ring-1{inset:42px}
.intro-ring.ring-2{inset:24px;animation-delay:.45s}
.intro-ring.ring-3{inset:6px;animation-delay:.9s}
.intro-character{position:relative;z-index:5;width:146px;height:146px;border-radius:38% 42% 44% 40%;background:radial-gradient(circle at 34% 22%,#ffffff 0%,#dbeafe 18%,#60a5fa 40%,#2563eb 67%,#1e1b4b 100%);box-shadow:0 0 18px rgba(255,255,255,0.72),0 0 54px rgba(56,189,248,0.88),0 0 110px rgba(79,70,229,0.46),0 32px 58px rgba(0,0,0,0.42),inset 0 2px 18px rgba(255,255,255,0.7);animation:introAiFloat 3s ease-in-out infinite}
.intro-character::before{content:"";position:absolute;left:50%;top:-24px;width:2px;height:28px;background:linear-gradient(180deg,rgba(255,255,255,0.85),rgba(125,211,252,0.2));transform:translateX(-50%);box-shadow:0 0 16px rgba(125,211,252,0.85)}
.intro-character::after{content:"";position:absolute;left:50%;top:-34px;width:14px;height:14px;border-radius:999px;background:#e0f2fe;transform:translateX(-50%);box-shadow:0 0 18px rgba(125,211,252,1),0 0 38px rgba(59,130,246,0.8);animation:introSignalDot 1.6s ease-in-out infinite}
.intro-light{position:absolute;left:30px;top:18px;width:52px;height:24px;border-radius:999px;background:rgba(255,255,255,0.72);filter:blur(2px);transform:rotate(-24deg)}
.intro-face{position:absolute;left:0;right:0;top:50px;display:flex;justify-content:center;gap:25px}
.intro-eye{width:18px;height:22px;border-radius:999px;background:linear-gradient(180deg,#e0f2fe,#38bdf8 46%,#0f172a 100%);box-shadow:0 0 12px rgba(224,242,254,0.95),0 0 24px rgba(56,189,248,0.85);animation:introBlink 4.2s infinite}
.intro-mouth{position:absolute;left:50%;top:91px;width:36px;height:12px;border-bottom:4px solid rgba(15,23,42,0.88);border-radius:0 0 999px 999px;transform:translateX(-50%);box-shadow:0 0 12px rgba(125,211,252,0.55);animation:introTalk 1.18s ease-in-out infinite}
.intro-core{position:absolute;left:50%;bottom:16px;width:24px;height:24px;border-radius:999px;background:radial-gradient(circle,#ffffff 0%,#67e8f9 42%,#2563eb 100%);box-shadow:0 0 16px rgba(103,232,249,0.95),0 0 34px rgba(37,99,235,0.85);transform:translateX(-50%);animation:introCorePulse 1.7s ease-in-out infinite}
.intro-shadow{position:absolute;left:50%;bottom:18px;width:128px;height:22px;border-radius:999px;background:rgba(0,0,0,0.34);filter:blur(8px);transform:translateX(-50%);animation:introShadow 2.8s ease-in-out infinite}
.intro-copy{position:relative;z-index:6}
.intro-badge{display:inline-flex;align-items:center;justify-content:center;margin-bottom:10px;padding:7px 15px;border-radius:999px;background:linear-gradient(135deg,rgba(14,165,233,0.22),rgba(168,85,247,0.18));border:1px solid rgba(186,230,253,0.36);box-shadow:0 0 24px rgba(56,189,248,0.18);font-size:12px;font-weight:950;color:#dbeafe;letter-spacing:1.1px}
.intro-copy h1{margin:0 0 8px;font-size:34px;line-height:1.16;font-weight:950;letter-spacing:-1.2px;color:#fff}
.intro-copy p{margin:0;font-size:16px;line-height:1.55;font-weight:850;color:#e5e7eb;word-break:keep-all}
.intro-ai-title{font-size:36px!important;line-height:1.2!important;letter-spacing:-1.4px!important;word-break:keep-all!important}
.intro-ai-title span{display:inline-block;color:#67e8f9!important;font-weight:950!important;text-shadow:0 0 18px rgba(103,232,249,0.72),0 0 32px rgba(59,130,246,0.5)}
.intro-simple-actions{position:relative;z-index:7;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;width:100%;max-width:360px;margin-top:4px}
.intro-command-input{position:absolute!important;left:-9999px!important;width:1px!important;height:1px!important;opacity:0!important;pointer-events:none!important}
.intro-main-mic-btn{width:132px;height:132px;border:0;border-radius:999px;background:transparent;color:#fff;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;box-shadow:none;cursor:pointer;animation:introMicFloat 2.6s ease-in-out infinite}
.intro-main-mic-btn::before{display:none;content:none}
.intro-main-mic-btn span{display:block;font-size:62px;line-height:1;background:none;box-shadow:none;filter:drop-shadow(0 10px 18px rgba(0,0,0,0.35))}
.intro-main-mic-btn strong{display:block;margin-top:0;font-size:28px;font-weight:950;letter-spacing:-0.7px;color:#fff;text-shadow:0 3px 10px rgba(0,0,0,0.45)}
.intro-main-mic-btn:active{transform:scale(.94)}
.intro-voice-status{width:auto!important;min-width:120px!important;min-height:32px!important;padding:7px 13px!important;border-radius:999px!important;background:rgba(15,23,42,0.72)!important;color:#dbeafe!important;border:1px solid rgba(125,211,252,0.28)!important;box-shadow:0 0 22px rgba(56,189,248,0.12)!important;font-size:12px!important;font-weight:900!important}
.intro-simple-guide{margin:0;color:#cbd5e1;font-size:13px;font-weight:850;line-height:1.45;text-align:center;word-break:keep-all}
.aisfor-intro-page.listening .intro-character{box-shadow:0 0 24px rgba(255,255,255,0.9),0 0 72px rgba(34,211,238,1),0 0 130px rgba(124,58,237,0.72),0 34px 62px rgba(0,0,0,0.45),inset 0 2px 18px rgba(255,255,255,0.78)}
.aisfor-intro-page.listening .intro-ring{border-color:rgba(103,232,249,0.72);box-shadow:0 0 42px rgba(34,211,238,0.38),inset 0 0 28px rgba(59,130,246,0.2)}
.aisfor-intro-page.listening .intro-main-mic-btn{box-shadow:none}
.aisfor-intro-page.listening .intro-main-mic-btn span{filter:drop-shadow(0 0 24px rgba(34,197,94,0.95)) drop-shadow(0 14px 24px rgba(0,0,0,0.35))}
@keyframes introAiFloat{0%,100%{transform:translateY(0) rotate(-1deg)}50%{transform:translateY(-13px) rotate(1.4deg)}}
@keyframes introAuraPulse{0%,100%{opacity:.42;transform:translate(-50%,-50%) scale(.96)}50%{opacity:.78;transform:translate(-50%,-50%) scale(1.05)}}
@keyframes introBgFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-18px)}}
@keyframes introBlink{0%,92%,100%{transform:scaleY(1)}95%{transform:scaleY(.12)}}
@keyframes introCorePulse{0%,100%{transform:translateX(-50%) scale(1);opacity:.92}50%{transform:translateX(-50%) scale(1.22);opacity:1}}
@keyframes introMicFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}
@keyframes introOrbitSpin{0%{transform:rotate(0deg)}100%{transform:rotate(360deg)}}
@keyframes introPulse{0%{opacity:.85;transform:scale(.82)}100%{opacity:0;transform:scale(1.18)}}
@keyframes introShadow{0%,100%{opacity:.34;transform:translateX(-50%) scale(1)}50%{opacity:.20;transform:translateX(-50%) scale(.82)}}
@keyframes introSignalDot{0%,100%{transform:translateX(-50%) scale(1);opacity:.82}50%{transform:translateX(-50%) scale(1.35);opacity:1}}
@keyframes introTalk{0%,100%{height:8px;width:24px}50%{height:15px;width:32px}}
@media(max-width:700px){
  .aisfor-intro-page{margin:-22px -14px -78px;padding:28px 14px 24px;gap:14px}
  .intro-character-zone{width:220px;height:220px}
  .intro-character{width:128px;height:128px}
  .intro-face{top:44px;gap:25px}
  .intro-mouth{top:80px}
  .intro-ai-title{font-size:24px!important;line-height:1.22!important;letter-spacing:-1px!important}
  .intro-copy p{font-size:15px}
  .intro-simple-actions{max-width:320px;gap:11px}
  .intro-main-mic-btn{width:118px;height:118px}
  .intro-main-mic-btn span{font-size:58px}
  .intro-main-mic-btn strong{font-size:26px}
  .intro-simple-guide{font-size:12px;padding:0 8px}
}
@media(max-width:380px){
  .intro-ai-title{font-size:22px!important}
}

/* 음악 녹음 입력 박스 정리 */
.music-info-box{display:flex;flex-direction:column;gap:16px;margin-top:16px!important;padding:18px!important;background:linear-gradient(145deg,#ffffff,#f8fbff)!important;border:1px solid rgba(191,219,254,0.95)!important;border-radius:var(--radius)!important;box-shadow:0 14px 30px rgba(15,23,42,0.07),inset 0 1px 0 rgba(255,255,255,0.95)!important}
.music-info-box label{display:flex!important;flex-direction:column!important;align-items:stretch!important;gap:8px!important;margin:0!important;font-size:17px!important;font-weight:950!important;color:#1e293b!important;line-height:1.35!important}
.music-info-box input,.music-info-box textarea{display:block!important;width:100%!important;max-width:100%!important;margin:0!important;border:1px solid rgba(148,163,184,0.62)!important;border-radius:var(--radius)!important;background:#ffffff!important;padding:15px 16px!important;font-size:17px!important;line-height:1.55!important;color:#0f172a!important;box-shadow:inset 0 1px 0 rgba(255,255,255,0.95),0 10px 22px rgba(15,23,42,0.05)!important}
.music-info-box textarea{min-height:130px!important;resize:vertical!important}
.music-info-box .date-option-guide{margin:2px 0 0!important;padding:14px!important;border-radius:var(--radius)!important;background:#f8fafc!important;border:1px solid #e2e8f0!important;color:#64748b!important;font-size:15px!important;font-weight:850!important;line-height:1.65!important}
.record-mode-box>label{margin-bottom:0!important}
.record-mode-box select{font-size:20px!important;font-weight:850!important}
@media(max-width:700px){.music-info-box{gap:14px!important;padding:16px!important}.music-info-box label{font-size:18px!important}.music-info-box input,.music-info-box textarea{font-size:18px!important;padding:14px 15px!important}.music-info-box textarea{min-height:150px!important}.music-info-box .date-option-guide{font-size:16px!important;line-height:1.7!important}}

.intro-pc-menu-btn{display:inline-flex;align-items:center;justify-content:center;min-width:180px;min-height:52px;margin-top:18px;padding:14px 22px;border-radius:999px;background:linear-gradient(135deg,#2563eb,#7c3aed);color:#ffffff;text-decoration:none;font-size:17px;font-weight:950;box-shadow:0 16px 34px rgba(37,99,235,0.34)}
.intro-pc-menu-btn:hover{transform:translateY(-2px);box-shadow:0 20px 42px rgba(37,99,235,0.42)}
@media(max-width:700px){.intro-pc-menu-btn{display:inline-flex;width:100%;min-height:50px;margin-top:10px;border-radius:var(--radius);font-size:15px}}

.web-password-guide{margin:-2px 0 12px;color:#b91c1c;font-size:13px;line-height:1.45;font-weight:900}
.web-login-info{margin-top:8px;padding:8px 10px;border-radius:var(--radius);background:#f8fafc;border:1px solid #e2e8f0;color:#334155;font-size:14px;font-weight:850}
.web-login-info.secret{background:#fef2f2;border-color:#fecaca;color:#991b1b}

.bookmarklet-box{margin:16px 0 20px;padding:16px;border:1px solid #bfdbfe;border-radius:var(--radius);background:linear-gradient(145deg,#eff6ff,#ffffff);box-shadow:0 12px 26px rgba(37,99,235,0.08)}
.bookmarklet-box strong{display:block;margin-bottom:6px;color:#1e3a8a;font-size:17px;font-weight:950}
.bookmarklet-box p{margin:0 0 12px;color:#475569;font-size:14px;line-height:1.55;font-weight:800}
.bookmarklet-install-btn{display:inline-flex;align-items:center;justify-content:center;min-height:42px;padding:10px 15px;border-radius:var(--radius);background:linear-gradient(135deg,#2563eb,#7c3aed);color:#ffffff;text-decoration:none;font-size:15px;font-weight:950;box-shadow:0 12px 26px rgba(37,99,235,0.24)}
.bookmarklet-install-btn:hover{transform:translateY(-2px)}

/* AISFOR 클라우드 */
.cloud-panel{padding:26px!important}
.cloud-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}
.cloud-usage-box{min-width:150px;background:#0f172a;color:#fff;border-radius:var(--radius);padding:14px;box-shadow:0 12px 26px rgba(15,23,42,0.18)}
.cloud-usage-box strong{display:block;font-size:24px;font-weight:950;line-height:1.1}
.cloud-usage-box span{display:block;margin-top:4px;font-size:13px;font-weight:900;color:#cbd5e1}
.cloud-usage-bar{height:9px;margin-top:11px;background:rgba(255,255,255,0.18);border-radius:999px;overflow:hidden}
.cloud-usage-bar i{display:block;height:100%;background:#60a5fa;border-radius:999px}
.cloud-breadcrumb{display:flex;align-items:center;flex-wrap:wrap;gap:8px;margin-top:16px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:var(--radius);padding:11px 13px;font-size:14px;font-weight:900;color:#334155}
.cloud-breadcrumb a{color:#2563eb;text-decoration:none}
.cloud-root-link,.cloud-home-link{display:inline-flex;align-items:center;justify-content:center;min-height:36px;background:#2563eb;color:#fff!important;border-radius:var(--radius);padding:8px 13px;box-shadow:0 8px 18px rgba(37,99,235,0.18)}
.cloud-home-link{margin-left:auto;background:#0f172a}
.cloud-action-panel h2,.cloud-list-panel h2{margin:0 0 14px;font-size:24px;font-weight:950;color:#0f172a}
.cloud-folder-form{display:grid;grid-template-columns:1fr auto;gap:10px;margin-top:12px}
.cloud-folder-form input{width:100%;border:1px solid rgba(148,163,184,0.58);border-radius:var(--radius);background:#fff;padding:15px 16px;font-size:17px;font-weight:800;outline:none}
.cloud-folder-form button{border:0;border-radius:var(--radius);background:#2563eb;color:#fff;padding:0 18px;font-size:16px;font-weight:950;cursor:pointer}
.cloud-hidden-voice-input{width:100%;border:1px solid #cbd5e1;border-radius:var(--radius);padding:13px 14px;font-size:16px;font-weight:800;background:#fff}
.cloud-voice-box{display:flex;flex-direction:column;gap:11px;margin:16px 0 12px;padding:14px}
.cloud-voice-head{display:flex;align-items:center;justify-content:space-between;gap:10px}
.cloud-voice-head strong{color:#0f172a;font-size:16px;font-weight:950}
.cloud-voice-head span{color:#64748b;font-size:12px;font-weight:850;text-align:right}
.cloud-voice-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.cloud-voice-actions .voice-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;min-height:72px;padding:12px}
.cloud-voice-actions .voice-btn strong{font-size:18px;font-weight:950}
.cloud-voice-actions .voice-btn span{font-size:12px;font-weight:850;opacity:.88}
.cloud-voice-state-row{display:grid;grid-template-columns:1fr auto;gap:8px}
.cloud-voice-state-row .voice-status{grid-column:auto;min-height:38px;font-size:13px}
.cloud-voice-cancel-btn{min-width:68px;border:1px solid #cbd5e1;border-radius:var(--radius);background:#fff;color:#475569;padding:0 12px;font-size:13px;font-weight:950;cursor:pointer}
.cloud-voice-guide{margin:10px 0 0}
.cloud-upload-form{display:flex;flex-direction:column;gap:14px}
.cloud-upload-form label{display:flex;flex-direction:column;gap:8px;font-size:15px;font-weight:950;color:#334155}
.cloud-upload-form input[type="file"]{width:100%;border:2px dashed #bfdbfe;border-radius:var(--radius);padding:14px;background:#fff;font-size:15px;font-weight:800}
.cloud-upload-form button:disabled{opacity:.72;cursor:wait}
.cloud-upload-overlay{display:none!important;position:fixed;inset:0;z-index:10000;align-items:center;justify-content:center;padding:18px;background:rgba(2,6,23,.72);backdrop-filter:blur(8px)}
.cloud-upload-overlay.is-open{display:flex!important}
.cloud-upload-progress-box{width:min(430px,92vw);border:1px solid rgba(191,219,254,.45);border-radius:18px;background:linear-gradient(145deg,#ffffff,#eef6ff);padding:28px 24px;box-shadow:0 34px 100px rgba(2,6,23,.42);text-align:center}
.cloud-upload-orbit{width:76px;height:76px;margin:0 auto 18px;border-radius:999px;border:8px solid #dbeafe;border-top-color:#2563eb;border-right-color:#7c3aed;animation:cloudUploadSpin .9s linear infinite}
.cloud-upload-progress-box strong{display:block;color:#0f172a;font-size:24px;font-weight:950;line-height:1.2}
.cloud-upload-progress-box p{margin:9px 0 18px;color:#475569;font-size:15px;font-weight:850;line-height:1.45}
.cloud-upload-progress-track{height:14px;border-radius:999px;background:#dbeafe;overflow:hidden;box-shadow:inset 0 2px 6px rgba(15,23,42,.12)}
.cloud-upload-progress-track i{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,#2563eb,#7c3aed,#06b6d4);transition:width .18s ease}
.cloud-upload-progress-box span{display:block;margin-top:12px;color:#1d4ed8;font-size:22px;font-weight:950}
@keyframes cloudUploadSpin{to{transform:rotate(360deg)}}
.cloud-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.cloud-item{position:relative;background:linear-gradient(145deg,#fff,#f8fafc);border:1px solid #e2e8f0;border-radius:var(--radius);padding:14px;box-shadow:0 12px 28px rgba(15,23,42,0.07)}
.cloud-item-main{display:grid;grid-template-columns:46px 1fr;grid-template-rows:auto auto;column-gap:12px;text-decoration:none;color:#0f172a}
.cloud-icon{grid-row:1/3;display:flex;align-items:center;justify-content:center;width:46px;height:46px;border-radius:var(--radius);background:#eff6ff;font-size:25px}
.cloud-item strong{font-size:17px;font-weight:950;line-height:1.35;word-break:keep-all;overflow-wrap:anywhere}
.cloud-item small{margin-top:4px;font-size:12px;font-weight:800;color:#64748b}
.cloud-delete-btn{border:0;border-radius:var(--radius);background:#dc2626;color:#fff;padding:8px 11px;font-size:13px;font-weight:950;cursor:pointer}
.cloud-folder-item .cloud-delete-btn{position:absolute;right:12px;bottom:12px}
.cloud-file-table-wrap{width:100%;overflow-x:auto;border:1px solid #dbeafe;border-radius:var(--radius);background:#fff}
.cloud-file-table{width:100%;min-width:760px;border-collapse:collapse;background:#fff;font-size:14px}
.cloud-file-table th{background:#0f172a;color:#fff;padding:11px 9px;text-align:center;font-size:13px;font-weight:950;white-space:nowrap}
.cloud-file-table td{border-bottom:1px solid #e5e7eb;padding:10px 9px;text-align:center;vertical-align:middle;font-weight:800;color:#334155}
.cloud-file-table tr:last-child td{border-bottom:0}
.cloud-file-name{text-align:left!important;color:#0f172a!important;font-weight:950!important;word-break:keep-all;overflow-wrap:anywhere}
.cloud-file-action-stack{display:flex;align-items:center;justify-content:center;gap:8px;flex-wrap:wrap}
.cloud-download-btn{display:inline-flex;align-items:center;justify-content:center;text-decoration:none;border-radius:var(--radius);background:#2563eb;color:#fff;padding:8px 11px;font-size:13px;font-weight:950}
.cloud-share-btn{display:inline-flex;align-items:center;justify-content:center;border:0;border-radius:var(--radius);background:#10b981;color:#fff;padding:8px 11px;font-size:13px;font-weight:950;cursor:pointer}
.cloud-section-title-row{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px}
.cloud-section-title-row h2{margin:0}
.cloud-section-title-row span{display:inline-flex;align-items:center;justify-content:center;min-width:44px;height:34px;border-radius:var(--radius);background:#eff6ff;color:#1d4ed8;font-size:14px;font-weight:950}
.cloud-gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.cloud-gallery-item{display:flex;flex-direction:column;min-width:0;background:#fff;border:1px solid #dbeafe;border-radius:var(--radius);overflow:hidden;box-shadow:0 12px 28px rgba(15,23,42,0.08)}
.cloud-gallery-preview{position:relative;width:100%;aspect-ratio:4/3;border:0;background:#0f172a;cursor:pointer;overflow:hidden}
.cloud-gallery-preview img{width:100%;height:100%;display:block;object-fit:cover}
.cloud-gallery-video-mark{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:#fff;background:linear-gradient(135deg,#111827,#334155);font-size:20px;font-weight:950;letter-spacing:0}
.cloud-gallery-info{display:flex;flex-direction:column;gap:5px;min-height:74px;padding:12px}
.cloud-gallery-info strong{font-size:15px;font-weight:950;color:#0f172a;line-height:1.35;word-break:keep-all;overflow-wrap:anywhere}
.cloud-gallery-info small{font-size:12px;font-weight:850;color:#64748b}
.cloud-gallery-download{display:flex;align-items:center;justify-content:center;margin:0 12px 12px;min-height:40px;border-radius:var(--radius);background:#2563eb;color:#fff;text-decoration:none;font-size:14px;font-weight:950}
@media(max-width:700px){.cloud-head{flex-direction:column}.cloud-usage-box{width:100%}.cloud-folder-form{grid-template-columns:1fr}.cloud-folder-form button{min-height:52px}.cloud-grid{grid-template-columns:1fr}.cloud-gallery-grid{grid-template-columns:1fr 1fr}.cloud-file-table{min-width:680px}.cloud-panel{padding:22px!important}}

.cloud-upload-form select{width:100%;border:1px solid rgba(148,163,184,0.58);border-radius:var(--radius);background:#fff;padding:15px 16px;font-size:17px;font-weight:900;color:#0f172a;outline:none}
.cloud-upload-form select:focus{border-color:#60a5fa;box-shadow:0 0 0 4px rgba(96,165,250,0.18)}

.cloud-preview-thumb-btn{width:70px;height:54px;border:0;border-radius:var(--radius);padding:0;background:#f8fafc;overflow:hidden;cursor:pointer;box-shadow:0 8px 18px rgba(15,23,42,0.08)}
.cloud-preview-thumb-btn img{width:100%;height:100%;object-fit:cover;display:block}
.cloud-file-icon{display:inline-flex;align-items:center;justify-content:center;width:70px;height:54px;border:0;border-radius:var(--radius);font-size:15px;font-weight:950;color:#fff;background:#64748b;text-decoration:none;cursor:default}
button.cloud-file-icon{cursor:pointer}
.cloud-file-icon.pdf{background:#dc2626}
.cloud-file-icon.video{background:#7c3aed;font-size:24px}
.cloud-file-icon.audio{background:#0891b2;font-size:24px}
.cloud-file-icon.word{background:#2563eb}
.cloud-file-icon.excel{background:#16a34a}
.cloud-file-icon.ppt{background:#ea580c}
.cloud-file-icon.hwp{background:#0f766e}
.cloud-file-icon.file{background:#475569}
.cloud-preview-modal{position:fixed;inset:0;z-index:9999;align-items:center;justify-content:center;padding:18px}
.cloud-preview-backdrop{position:absolute;inset:0;background:rgba(2,6,23,0.72)}
.cloud-preview-box{position:relative;z-index:2;width:min(960px,96vw);height:min(760px,88vh);background:#fff;border-radius:var(--radius);box-shadow:0 30px 90px rgba(0,0,0,0.35);overflow:hidden;display:flex;flex-direction:column}
.cloud-preview-head{display:flex;align-items:center;justify-content:space-between;gap:10px;background:#0f172a;color:#fff;padding:13px 15px}
.cloud-preview-head strong{font-size:16px;font-weight:950;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cloud-preview-head button{border:0;border-radius:var(--radius);background:#fff;color:#0f172a;padding:8px 12px;font-size:14px;font-weight:950;cursor:pointer}
.cloud-preview-actions{display:flex;align-items:center;gap:8px}
.cloud-preview-actions span{font-size:13px;font-weight:950;color:#cbd5e1;white-space:nowrap}
.cloud-preview-actions a{align-items:center;justify-content:center;min-height:34px;border-radius:var(--radius);background:#2563eb;color:#fff;text-decoration:none;padding:7px 11px;font-size:13px;font-weight:950}
.cloud-preview-share-btn{align-items:center;justify-content:center;min-height:34px;border:0;border-radius:var(--radius);background:#10b981;color:#fff;padding:7px 11px;font-size:13px;font-weight:950;cursor:pointer}
.cloud-preview-body{flex:1;display:flex;align-items:center;justify-content:center;background:#f8fafc;overflow:auto;padding:12px;touch-action:pan-y}
.cloud-preview-body img{max-width:100%;max-height:100%;object-fit:contain;border-radius:var(--radius)}
.cloud-preview-body iframe{width:100%;height:100%;border:0;background:#fff}
.cloud-preview-body video{max-width:100%;max-height:100%;background:#000;border-radius:var(--radius)}
.cloud-preview-body audio{width:min(640px,92vw)}
.cloud-preview-nav{position:absolute;top:50%;z-index:4;display:none;align-items:center;justify-content:center;width:46px;height:58px;transform:translateY(-50%);border:0;border-radius:var(--radius);background:rgba(15,23,42,0.82);color:#fff;font-size:42px;font-weight:700;line-height:1;cursor:pointer;box-shadow:0 10px 28px rgba(15,23,42,0.28)}
.cloud-preview-nav.prev{left:14px}
.cloud-preview-nav.next{right:14px}
@media(max-width:700px){.cloud-file-icon,.cloud-preview-thumb-btn{width:58px;height:48px}.cloud-preview-box{width:96vw;height:82vh}.cloud-preview-head{align-items:flex-start}.cloud-preview-head strong{font-size:14px}.cloud-preview-actions{flex-wrap:wrap;justify-content:flex-end}.cloud-preview-nav{width:40px;height:52px;font-size:36px}}

.ai-chat-panel{display:flex;flex-direction:column;gap:16px;min-height:calc(100vh - 220px)}
.ai-chat-head{display:flex;align-items:flex-start;justify-content:space-between;gap:14px}
.ai-chat-head h1{margin:0;font-size:34px;font-weight:950;color:#0f172a}
.ai-speak-toggle{border:0;border-radius:var(--radius);background:#0f172a;color:#fff;padding:11px 14px;font-size:14px;font-weight:950;cursor:pointer;white-space:nowrap}
.ai-speak-toggle.active{background:#2563eb}
.ai-chat-box{height:min(46vh,560px);min-height:300px;overflow:auto;background:linear-gradient(145deg,#f8fafc,#eef6ff);border:1px solid #dbeafe;border-radius:var(--radius);padding:18px;box-shadow:inset 0 1px 0 rgba(255,255,255,.88)}
.ai-message{display:flex;gap:10px;margin-bottom:14px;align-items:flex-start}
.ai-message.user{flex-direction:row-reverse}
.ai-avatar{display:flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:999px;background:#0f172a;color:#fff;font-size:13px;font-weight:950;flex:0 0 auto}
.ai-message.user .ai-avatar{background:#2563eb}
.ai-bubble{max-width:min(720px,78%);border-radius:16px;background:#fff;padding:13px 15px;color:#0f172a;font-size:16px;font-weight:800;line-height:1.55;box-shadow:0 10px 24px rgba(15,23,42,.08);white-space:pre-wrap}
.ai-message.user .ai-bubble{background:#2563eb;color:#fff}
.ai-action-box{display:flex;flex-wrap:wrap;gap:8px}
.ai-action-box a,.ai-action-box button{display:inline-flex;align-items:center;justify-content:center;min-height:40px;border:0;border-radius:var(--radius);background:#0f172a;color:#fff;text-decoration:none;padding:8px 13px;font-size:14px;font-weight:950;cursor:pointer}
.ai-voice-command-box{display:grid;grid-template-columns:minmax(220px,320px) 1fr;align-items:center;gap:12px;padding:14px;border:1px solid #bfdbfe;border-radius:var(--radius);background:linear-gradient(145deg,#eff6ff,#ffffff);box-shadow:0 12px 28px rgba(37,99,235,.08)}
.ai-voice-command-actions{display:grid;grid-template-columns:1fr;gap:8px}
.ai-big-mic-btn{min-height:66px;border:0;border-radius:var(--radius);background:linear-gradient(135deg,#2563eb,#7c3aed);color:#fff;font-size:22px;font-weight:950;cursor:pointer;box-shadow:0 16px 34px rgba(37,99,235,.28)}
.ai-voice-finish-btn{min-height:42px;border:0;border-radius:var(--radius);background:linear-gradient(135deg,#059669,#15803d);color:#fff;font-size:15px;font-weight:950;cursor:pointer;box-shadow:0 9px 18px rgba(5,150,105,.20)}
.ai-voice-command-box p{margin:0;color:#334155;font-size:15px;font-weight:850;line-height:1.55}
.ai-voice-finish-guide{grid-column:1/-1;display:flex;flex-direction:column;gap:4px;padding:11px 12px;border:1px solid #fde68a;border-radius:var(--radius);background:#fffbeb;color:#78350f;line-height:1.45}
.ai-voice-finish-guide strong{font-size:15px;font-weight:950}.ai-voice-finish-guide span{font-size:13px;font-weight:900}.ai-voice-finish-guide small{font-size:12px;font-weight:800;color:#92400e}
.ai-push-box{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px;border:1px solid #a7f3d0;border-radius:var(--radius);background:#ecfdf5;color:#065f46}.ai-push-box div{display:flex;flex-direction:column;gap:3px}.ai-push-box strong{font-size:15px;font-weight:950}.ai-push-box span{font-size:12px;font-weight:800;line-height:1.4}.ai-push-box button{min-width:126px;min-height:42px;border:0;border-radius:var(--radius);background:#059669;color:#fff;font-size:14px;font-weight:950;cursor:pointer}.ai-push-box button:disabled{opacity:.72;cursor:default}
.ai-chat-form{display:grid;grid-template-columns:1fr auto;gap:10px}
.ai-chat-form input{width:100%;border:1px solid rgba(148,163,184,.62);border-radius:var(--radius);background:#fff;padding:15px 16px;font-size:17px;font-weight:850;outline:none}
.ai-chat-form button{border:0;border-radius:var(--radius);background:#2563eb;color:#fff;padding:0 17px;font-size:16px;font-weight:950;cursor:pointer}
.ai-chat-form .ai-mic-btn{background:linear-gradient(135deg,#4f46e5,#7c3aed)}
.ai-voice-status{margin:0}
@media(max-width:700px){.ai-chat-panel{gap:12px}.ai-chat-head{flex-direction:column;gap:8px}.ai-chat-head h1{font-size:28px}.ai-chat-head .desc{margin-bottom:6px}.ai-chat-box{height:34vh;min-height:220px;padding:14px}.ai-bubble{max-width:82%;font-size:15px}.ai-voice-command-box{grid-template-columns:1fr;padding:12px}.ai-big-mic-btn{min-height:76px;font-size:23px}.ai-chat-form{grid-template-columns:1fr}.ai-chat-form button{min-height:52px}}
@media(max-width:700px){.ai-push-box{align-items:stretch;flex-direction:column}.ai-push-box button{width:100%}}

@media(min-width:701px){
  body:has(.cloud-panel) .page{max-width:1100px;padding-left:24px;padding-right:24px}
  body:has(.cloud-panel) .panel{padding-left:34px;padding-right:34px}
  body:has(.cloud-panel) .cloud-file-table{min-width:0;width:100%;table-layout:fixed}
  body:has(.cloud-panel) .cloud-file-table th:nth-child(1),body:has(.cloud-panel) .cloud-file-table td:nth-child(1){width:100px}
  body:has(.cloud-panel) .cloud-file-table th:nth-child(2),body:has(.cloud-panel) .cloud-file-table td:nth-child(2){width:190px}
  body:has(.cloud-panel) .cloud-file-table th:nth-child(3),body:has(.cloud-panel) .cloud-file-table td:nth-child(3){width:210px}
  body:has(.cloud-panel) .cloud-file-table th:nth-child(4),body:has(.cloud-panel) .cloud-file-table td:nth-child(4){width:90px}
  body:has(.cloud-panel) .cloud-file-table th:nth-child(5),body:has(.cloud-panel) .cloud-file-table td:nth-child(5){width:160px}
  body:has(.cloud-panel) .cloud-file-table th:nth-child(6),body:has(.cloud-panel) .cloud-file-table td:nth-child(6){width:100px}
  body:has(.cloud-panel) .cloud-file-table th:nth-child(7),body:has(.cloud-panel) .cloud-file-table td:nth-child(7){width:82px}
  body:has(.cloud-panel) .cloud-file-table td{word-break:break-word}
}

@media(max-width:700px){
  body:has(.cloud-panel) .page{padding:0 14px 70px}
  body:has(.cloud-panel) .panel{padding:22px 18px;border-radius:14px}
  body:has(.cloud-panel) .cloud-head{display:block}
  body:has(.cloud-panel) .cloud-usage-box{margin-top:14px;width:100%}
  body:has(.cloud-panel) .cloud-grid{display:flex;flex-direction:column;gap:14px}
  body:has(.cloud-panel) .cloud-gallery-grid{display:grid;grid-template-columns:1fr;gap:14px}
  body:has(.cloud-panel) .cloud-gallery-preview{aspect-ratio:16/10}
  body:has(.cloud-panel) .cloud-gallery-info strong{font-size:18px}
  body:has(.cloud-panel) .cloud-gallery-download{min-height:52px;font-size:16px}
  body:has(.cloud-panel) .cloud-item{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:18px 16px;border-radius:14px}
  body:has(.cloud-panel) .cloud-item-main{display:grid;grid-template-columns:64px 1fr;gap:0 14px;align-items:center;min-width:0}
  body:has(.cloud-panel) .cloud-icon{grid-row:1 / span 2;width:64px;height:64px;display:flex;align-items:center;justify-content:center;border-radius:12px;background:#eef6ff;font-size:32px}
  body:has(.cloud-panel) .cloud-item-main strong{font-size:22px;line-height:1.25;word-break:break-word}
  body:has(.cloud-panel) .cloud-item-main small{font-size:15px;color:#64748b;line-height:1.35}
  body:has(.cloud-panel) .cloud-file-table-wrap{overflow:visible}
  body:has(.cloud-panel) .cloud-file-table{display:block;width:100%;min-width:0;border-collapse:separate;border-spacing:0}
  body:has(.cloud-panel) .cloud-file-table thead{display:none}
  body:has(.cloud-panel) .cloud-file-table tbody{display:flex;flex-direction:column;gap:18px}
  body:has(.cloud-panel) .cloud-file-table tr{display:grid;grid-template-columns:92px 1fr;gap:8px 14px;padding:18px 16px;background:#ffffff;border-radius:14px;box-shadow:0 10px 24px rgba(15,23,42,.08)}
  body:has(.cloud-panel) .cloud-file-table td{display:block;padding:0;border:0;background:transparent;color:#111827;font-size:16px;font-weight:800;line-height:1.35;word-break:break-word;overflow-wrap:anywhere}
  body:has(.cloud-panel) .cloud-file-table td:nth-child(1){grid-row:1 / span 4;display:flex;align-items:center;justify-content:center}
  body:has(.cloud-panel) .cloud-file-table td:nth-child(2){font-size:20px;color:#0f172a}
  body:has(.cloud-panel) .cloud-file-table td:nth-child(3){display:none}
  body:has(.cloud-panel) .cloud-file-table td:nth-child(4)::before{content:'용량 ';display:inline;font-size:14px;color:#64748b;font-weight:900;margin-right:6px}
  body:has(.cloud-panel) .cloud-file-table td:nth-child(5)::before{content:'날짜 ';display:inline;font-size:14px;color:#64748b;font-weight:900;margin-right:6px}
  body:has(.cloud-panel) .cloud-file-table td:nth-child(6){display:inline-flex}
  body:has(.cloud-panel) .cloud-file-table td:nth-child(7){display:inline-flex}
  body:has(.cloud-panel) .cloud-preview-thumb-btn{width:78px;height:78px;border-radius:12px}
  body:has(.cloud-panel) .cloud-preview-thumb-btn img{width:78px;height:78px;object-fit:cover;border-radius:12px}
  body:has(.cloud-panel) .cloud-file-icon{width:78px;height:78px;border-radius:12px;font-size:18px}
  body:has(.cloud-panel) .cloud-download-btn,
  body:has(.cloud-panel) .cloud-share-btn{width:96px;min-height:54px;padding:0 12px;border-radius:12px;font-size:16px;line-height:1.15;display:flex;align-items:center;justify-content:center;text-align:center}
  body:has(.cloud-panel) .cloud-delete-btn{width:74px;min-height:54px;padding:0 12px;border-radius:12px;font-size:16px;line-height:1.15;display:flex;align-items:center;justify-content:center;text-align:center}
}

body:has(.cloud-panel) .cloud-file-table th:nth-child(1),body:has(.cloud-panel) .cloud-file-table td:nth-child(1){width:110px}
body:has(.cloud-panel) .cloud-file-table th:nth-child(2),body:has(.cloud-panel) .cloud-file-table td:nth-child(2){width:auto}
body:has(.cloud-panel) .cloud-file-table th:nth-child(3),body:has(.cloud-panel) .cloud-file-table td:nth-child(3){width:110px}
body:has(.cloud-panel) .cloud-file-table th:nth-child(4),body:has(.cloud-panel) .cloud-file-table td:nth-child(4){width:180px}
body:has(.cloud-panel) .cloud-file-table th:nth-child(5),body:has(.cloud-panel) .cloud-file-table td:nth-child(5){width:110px}
body:has(.cloud-panel) .cloud-file-table th:nth-child(6),body:has(.cloud-panel) .cloud-file-table td:nth-child(6){width:90px}

.diary-calendar-box{scroll-margin-top:96px;margin:14px 0 16px;background:linear-gradient(145deg,rgba(255,255,255,0.92),rgba(239,246,255,0.74));border:1px solid rgba(191,219,254,0.88);border-radius:var(--radius);padding:16px;box-shadow:0 16px 34px rgba(15,23,42,0.07),inset 0 1px 0 rgba(255,255,255,0.9)}
.diary-calendar-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:12px}
.diary-calendar-head strong{font-size:20px;font-weight:950;color:#0f172a}
.diary-calendar-head span{display:inline-flex;align-items:center;justify-content:center;min-height:30px;border-radius:var(--radius);background:#eff6ff;color:#1d4ed8;padding:5px 10px;font-size:13px;font-weight:950}
.diary-month-nav{display:inline-flex;align-items:center;justify-content:center;min-height:30px;border:1px solid #bfdbfe;border-radius:var(--radius);background:#fff;color:#2563eb;padding:5px 10px;font-size:13px;font-weight:950;text-decoration:none}
.diary-calendar-week,.diary-calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}
.diary-calendar-week{margin-bottom:6px}
.diary-calendar-week span{display:flex;align-items:center;justify-content:center;color:#64748b;font-size:13px;font-weight:950}
.diary-day{position:relative;display:flex;align-items:flex-start;justify-content:flex-start;min-height:54px;border:1px solid #e2e8f0;border-radius:var(--radius);background:#fff;color:#0f172a;padding:8px;font-size:15px;font-weight:950}
button.diary-day{cursor:pointer}
.diary-day.empty{background:transparent;border:0}
.diary-day.has-diary{background:linear-gradient(145deg,#dbeafe,#fff);border-color:#93c5fd;box-shadow:0 10px 22px rgba(37,99,235,.12)}
.diary-day.selected{background:#2563eb;color:#fff;border-color:#2563eb;box-shadow:0 14px 28px rgba(37,99,235,.25)}
.diary-day.has-diary::after{content:"";position:absolute;left:8px;right:8px;bottom:7px;height:4px;border-radius:999px;background:#2563eb}
.diary-day.selected::after{background:#fff}
.diary-day em{position:absolute;right:6px;top:6px;display:flex;align-items:center;justify-content:center;min-width:20px;height:20px;border-radius:999px;background:#2563eb;color:#fff;font-style:normal;font-size:11px;font-weight:950}
.diary-day.selected em{background:#fff;color:#2563eb}
.diary-read-box{margin-top:14px;border:1px solid #dbeafe;border-radius:var(--radius);background:#fff;padding:13px 14px;color:#334155;font-size:15px;font-weight:850;line-height:1.55}
.diary-read-box strong{display:block;color:#0f172a;font-size:16px;font-weight:950;margin-bottom:6px}
.diary-read-box p{margin:0;white-space:pre-wrap;word-break:keep-all;overflow-wrap:anywhere}
.diary-read-actions{display:flex;justify-content:flex-end;margin-top:12px}
.diary-read-actions .delete-btn{min-height:40px;padding:9px 14px}
.diary-read-media{display:grid;grid-template-columns:1fr;gap:10px;margin-top:12px}
.diary-read-media-item{border:1px solid #dbeafe;border-radius:var(--radius);background:#f8fafc;padding:8px}
.diary-read-media img,.diary-read-media video{display:block;width:100%;max-height:420px;object-fit:contain;border-radius:var(--radius);background:#000}

@media(max-width:700px){
  body:has(.cloud-panel) .cloud-file-table tr{grid-template-columns:92px 1fr;gap:8px 14px}
  body:has(.cloud-panel) .cloud-file-table td:nth-child(1){grid-row:1 / span 4}
  body:has(.cloud-panel) .cloud-file-table td:nth-child(2){font-size:20px;color:#0f172a}
  body:has(.cloud-panel) .cloud-file-table td:nth-child(3)::before{content:'용량 ';display:inline;font-size:14px;color:#64748b;font-weight:900;margin-right:6px}
  body:has(.cloud-panel) .cloud-file-table td:nth-child(4)::before{content:'날짜 ';display:inline;font-size:14px;color:#64748b;font-weight:900;margin-right:6px}
  body:has(.cloud-panel) .cloud-file-table td:nth-child(5){display:inline-flex}
  body:has(.cloud-panel) .cloud-file-table td:nth-child(6){display:inline-flex}
}

@media(max-width:700px){
  body:has(.cloud-panel) .cloud-file-table tbody{gap:14px}
  body:has(.cloud-panel) .cloud-file-table tr{
    grid-template-columns:88px minmax(0,1fr);
    grid-template-rows:auto auto auto auto;
    gap:7px 12px;
    padding:15px;
  }
  body:has(.cloud-panel) .cloud-file-table td{width:auto!important;min-width:0}
  body:has(.cloud-panel) .cloud-file-table td:nth-child(1){grid-column:1;grid-row:1 / span 3;align-self:center}
  body:has(.cloud-panel) .cloud-file-table td:nth-child(2){grid-column:2;grid-row:1;font-size:17px;line-height:1.3}
  body:has(.cloud-panel) .cloud-file-table td:nth-child(3){display:block;grid-column:2;grid-row:2;color:#475569;font-size:14px}
  body:has(.cloud-panel) .cloud-file-table td:nth-child(4){display:block;grid-column:2;grid-row:3;color:#475569;font-size:14px}
  body:has(.cloud-panel) .cloud-file-table td:nth-child(5){display:flex;grid-column:1;grid-row:4}
  body:has(.cloud-panel) .cloud-file-table td:nth-child(6){display:flex;grid-column:2;grid-row:4}
  body:has(.cloud-panel) .cloud-file-table td:nth-child(3)::before{content:'용량';display:inline-block;min-width:38px;margin-right:5px;font-size:13px}
  body:has(.cloud-panel) .cloud-file-table td:nth-child(4)::before{content:'날짜';display:inline-block;min-width:38px;margin-right:5px;font-size:13px}
  body:has(.cloud-panel) .cloud-file-table td:nth-child(5)::before,
  body:has(.cloud-panel) .cloud-file-table td:nth-child(6)::before{content:none}
  body:has(.cloud-panel) .cloud-preview-thumb-btn,
  body:has(.cloud-panel) .cloud-preview-thumb-btn img,
  body:has(.cloud-panel) .cloud-file-icon{width:76px;height:76px}
  body:has(.cloud-panel) .cloud-file-table .cloud-download-btn,
  body:has(.cloud-panel) .cloud-file-table .cloud-share-btn,
  body:has(.cloud-panel) .cloud-file-table .cloud-delete-btn{width:100%;min-height:48px;border-radius:10px;font-size:15px}
  body:has(.cloud-panel) .cloud-folder-item{padding-right:86px}
  body:has(.cloud-panel) .cloud-folder-item .cloud-delete-btn{right:14px;bottom:auto;top:50%;width:auto;min-height:42px;padding:0 13px;transform:translateY(-50%);border-radius:10px;font-size:14px}
  body:has(.cloud-panel) .cloud-voice-box{gap:9px;margin:14px 0 10px;padding:12px}
  body:has(.cloud-panel) .cloud-voice-head{align-items:flex-start;flex-direction:column;gap:3px}
  body:has(.cloud-panel) .cloud-voice-head strong{font-size:15px}
  body:has(.cloud-panel) .cloud-voice-head span{font-size:11px;text-align:left}
  body:has(.cloud-panel) .cloud-voice-actions{grid-template-columns:1fr 1fr;gap:8px}
  body:has(.cloud-panel) .cloud-voice-actions .voice-btn{width:100%;min-height:62px;padding:9px 7px}
  body:has(.cloud-panel) .cloud-voice-actions .voice-btn strong{font-size:16px}
  body:has(.cloud-panel) .cloud-voice-actions .voice-btn span{font-size:11px}
  body:has(.cloud-panel) .cloud-voice-state-row{gap:7px}
  body:has(.cloud-panel) .cloud-voice-state-row .voice-status{min-height:36px;padding:6px;font-size:12px}
  body:has(.cloud-panel) .cloud-voice-cancel-btn{min-width:62px;padding:0 9px;font-size:12px}
  body:has(.cloud-panel) .cloud-hidden-voice-input{padding:11px 12px;font-size:14px}
  body:has(.cloud-panel) .cloud-voice-guide{margin-top:8px;font-size:12px;line-height:1.55}
}

.section-head-actions{
  display:flex;
  align-items:center;
  gap:10px;
}

.chatgpt-text-btn{
  position:relative!important;
  min-width:124px!important;
  height:42px!important;
  overflow:hidden!important;
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  gap:8px!important;
  padding:0 17px!important;
  border-radius:999px!important;
  background:linear-gradient(135deg,#10a37f 0%,#19c37d 45%,#22c55e 100%)!important;
  color:#ffffff!important;
  border:1px solid rgba(255,255,255,0.45)!important;
  font-family:ui-sans-serif,-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Arial,"Noto Sans KR",sans-serif!important;
  font-size:15px!important;
  font-weight:950!important;
  letter-spacing:-0.25px!important;
  text-shadow:0 1px 2px rgba(0,0,0,0.22)!important;
  box-shadow:0 12px 28px rgba(16,163,127,0.38),0 0 0 4px rgba(16,163,127,0.14),inset 0 1px 0 rgba(255,255,255,0.34)!important;
  animation:chatgptPulse 1.9s ease-in-out infinite!important;
}

.chatgpt-text-btn::before{
  content:"";
  width:20px;
  height:20px;
  flex:0 0 20px;
  border-radius:50%;
  background:#ffffff;
  box-shadow:inset 0 0 0 5px #10a37f,0 0 0 3px rgba(255,255,255,0.28);
}

.chatgpt-text-btn::after{
  content:"";
  position:absolute;
  top:-60%;
  left:-35%;
  width:36px;
  height:220%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,0.72),transparent);
  transform:rotate(24deg);
  animation:chatgptShine 2.6s ease-in-out infinite;
}

.chatgpt-text-btn:hover{
  transform:translateY(-2px) scale(1.04)!important;
  background:linear-gradient(135deg,#059669 0%,#10a37f 42%,#22c55e 100%)!important;
  box-shadow:0 18px 36px rgba(16,163,127,0.48),0 0 0 5px rgba(16,163,127,0.18),inset 0 1px 0 rgba(255,255,255,0.42)!important;
}

.chatgpt-text-btn:active{
  transform:translateY(0) scale(0.98)!important;
}

@keyframes chatgptPulse{
  0%,100%{box-shadow:0 12px 28px rgba(16,163,127,0.38),0 0 0 4px rgba(16,163,127,0.14),inset 0 1px 0 rgba(255,255,255,0.34)}
  50%{box-shadow:0 16px 34px rgba(16,163,127,0.52),0 0 0 7px rgba(16,163,127,0.20),inset 0 1px 0 rgba(255,255,255,0.42)}
}

@keyframes chatgptShine{
  0%{left:-45%;opacity:0}
  35%{opacity:0}
  55%{opacity:1}
  100%{left:125%;opacity:0}
}

@media(max-width:700px){
  .section-head-actions{
    gap:7px;
  }

  .chatgpt-text-btn{
    min-width:104px!important;
    height:38px!important;
    padding:0 12px!important;
    font-size:13px!important;
  }

  .chatgpt-text-btn::before{
    width:17px;
    height:17px;
    flex-basis:17px;
    box-shadow:inset 0 0 0 4px #10a37f,0 0 0 3px rgba(255,255,255,0.25);
  }
}

@media(max-width:700px){
  .upcoming-panel{padding:14px 14px!important;border-radius:14px!important;margin-bottom:14px!important}
  .upcoming-panel .section-head{display:flex!important;align-items:center!important;justify-content:space-between!important;gap:8px!important;margin-bottom:10px!important}
  .upcoming-panel .section-head h2{font-size:20px!important;line-height:1.1!important;margin:0!important;white-space:nowrap!important}
  .upcoming-panel .section-head-actions{display:flex!important;align-items:center!important;gap:6px!important;flex-shrink:0!important}
  .upcoming-panel .small-link-btn{height:32px!important;padding:0 10px!important;font-size:12px!important;border-radius:9px!important;white-space:nowrap!important}
  .upcoming-panel .chatgpt-text-btn{min-width:92px!important;height:34px!important;padding:0 10px!important;font-size:12px!important}
  .upcoming-panel .chatgpt-text-btn::before{width:15px!important;height:15px!important;flex-basis:15px!important}
  .upcoming-list-compact{margin-top:0!important}
  .upcoming-list-compact .upcoming-item{display:grid!important;grid-template-columns:46px 1fr!important;gap:10px!important;padding:10px 12px!important;border-radius:12px!important;min-height:auto!important}
  .upcoming-list-compact .upcoming-dday{width:46px!important;height:42px!important;font-size:14px!important;border-radius:8px!important}
  .upcoming-list-compact .upcoming-body{min-width:0!important}
  .upcoming-list-compact .upcoming-meta{display:flex!important;align-items:center!important;gap:6px!important;margin-bottom:3px!important;white-space:nowrap!important;overflow:hidden!important}
  .upcoming-list-compact .upcoming-meta span{font-size:11px!important;padding:3px 6px!important;white-space:nowrap!important}
  .upcoming-list-compact .upcoming-content{font-size:14px!important;line-height:1.25!important;white-space:nowrap!important;overflow:hidden!important;text-overflow:ellipsis!important}
  .upcoming-dropdown summary{padding:9px 10px!important;font-size:13px!important;border-radius:10px!important;text-align:center!important}
}

.admin-plan-guide{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin:18px 0 22px}
.admin-plan-guide div{border-radius:12px;padding:14px 16px;border:1px solid #dbeafe;background:#ffffff;box-shadow:0 10px 22px rgba(15,23,42,0.06)}
.admin-plan-guide strong{display:block;font-size:16px;font-weight:950;color:#0f172a;margin-bottom:6px}
.admin-plan-guide span{display:block;font-size:13px;font-weight:850;color:#475569;line-height:1.45}
.admin-plan-guide .free{border-color:#e5e7eb}
.admin-plan-guide .standard{border-color:#bfdbfe;background:linear-gradient(145deg,#ffffff,#eff6ff)}
.admin-plan-guide .premium{border-color:#ddd6fe;background:linear-gradient(145deg,#ffffff,#f5f3ff)}
.admin-mini-badge.standard{background:#dbeafe;color:#1e40af}
.admin-mini-badge.premium{background:#fef3c7;color:#92400e}
.admin-plan-select option[value="premium"]{font-weight:900}
.cloud-plan-badge{display:inline-flex;align-items:center;justify-content:center;margin-bottom:8px;border-radius:999px;padding:5px 10px;font-size:12px;font-weight:950;line-height:1}
.cloud-plan-badge.free{background:#f3f4f6;color:#374151}
.cloud-plan-badge.standard{background:#dbeafe;color:#1e40af}
.cloud-plan-badge.premium{background:#fef3c7;color:#92400e}
.cloud-disabled-label{opacity:.72}
.cloud-disabled-label input{cursor:not-allowed;background:#f3f4f6}
.cloud-plan-limit-text{display:block;margin-top:7px;color:#b45309;font-size:13px;font-weight:900;line-height:1.45}

@media(max-width:700px){
  .admin-plan-guide{grid-template-columns:1fr}
}

.admin-mini-badge.plan.free{background:#f3f4f6;color:#374151;border:1px solid #d1d5db}
.admin-mini-badge.plan.standard{background:#dbeafe;color:#1e40af;border:1px solid #93c5fd}
.admin-mini-badge.plan.premium{background:#fef3c7;color:#92400e;border:1px solid #fbbf24}

.billing-current-card{border-radius:14px;padding:18px;background:#ffffff;border:1px solid #dbeafe;box-shadow:0 14px 30px rgba(15,23,42,0.08)}
.billing-current-card.standard{background:linear-gradient(145deg,#ffffff,#eff6ff)}
.billing-current-card.premium{background:linear-gradient(145deg,#ffffff,#f5f3ff)}
.billing-plan-name{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px;font-size:16px;font-weight:900;color:#475569}
.billing-plan-name strong{font-size:28px;font-weight:950;color:#0f172a}
.billing-usage-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.billing-usage-grid div{background:#f8fafc;border:1px solid #e5e7eb;border-radius:12px;padding:13px}
.billing-usage-grid span{display:block;margin-bottom:5px;font-size:13px;font-weight:900;color:#64748b}
.billing-usage-grid strong{display:block;font-size:18px;font-weight:950;color:#111827}
.billing-plan-table-wrap{overflow-x:auto;border:1px solid #dbeafe;border-radius:12px;background:#ffffff}
.billing-plan-table{width:100%;min-width:680px;border-collapse:collapse}
.billing-plan-table th{background:#0f172a;color:#ffffff;padding:12px;font-size:14px;font-weight:950;text-align:center}
.billing-plan-table td{border-bottom:1px solid #e5e7eb;padding:12px;text-align:center;font-size:14px;font-weight:850;color:#111827}
.billing-request-form label{display:flex;flex-direction:column;gap:7px;margin-bottom:12px;font-size:15px;font-weight:950;color:#334155}
.billing-request-form select,.billing-request-form input,.billing-request-form textarea{width:100%;border:1px solid #cbd5e1;border-radius:12px;background:#ffffff;padding:14px;font-size:16px;font-weight:850;color:#0f172a}
.billing-pending-box{display:flex;flex-direction:column;gap:5px;margin-bottom:14px;border:1px solid #fde68a;background:#fffbeb;color:#92400e;border-radius:12px;padding:14px;font-weight:900}
.billing-pending-box span{font-size:14px;line-height:1.45}
.admin-billing-request-section{margin:20px 0 22px}
.admin-billing-request-section h2{margin:0 0 12px;font-size:24px;font-weight:950;color:#0f172a}
.admin-billing-request-list{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:18px}
.admin-billing-request-card{background:#ffffff;border:1px solid #dbeafe;border-radius:14px;padding:15px;box-shadow:0 12px 26px rgba(15,23,42,0.07)}
.admin-billing-request-head{display:flex;flex-wrap:wrap;align-items:center;gap:7px;margin-bottom:10px}
.admin-billing-request-head strong{font-size:17px;font-weight:950;color:#111827}
.admin-billing-request-head span{background:#f3f4f6;border-radius:999px;padding:5px 8px;font-size:12px;font-weight:900;color:#475569}
.admin-billing-request-head b{background:#dbeafe;color:#1e40af;border-radius:999px;padding:5px 8px;font-size:12px;font-weight:950}
.admin-billing-request-body{display:flex;flex-direction:column;gap:5px;font-size:14px;font-weight:850;color:#475569;line-height:1.45}
.admin-billing-request-body b{color:#111827}
.admin-billing-request-memo{margin-top:7px;background:#f8fafc;border:1px solid #e5e7eb;border-radius:10px;padding:10px;color:#334155;white-space:pre-wrap}
.admin-billing-request-actions{display:flex;gap:8px;margin-top:12px}
.admin-billing-request-actions form{flex:1}
.admin-approve-btn,.admin-reject-btn{width:100%;border:0;border-radius:10px;padding:11px 12px;font-size:14px;font-weight:950;color:#ffffff;cursor:pointer}
.admin-approve-btn{background:linear-gradient(135deg,#2563eb,#1e40af)}
.admin-reject-btn{background:linear-gradient(135deg,#ef4444,#b91c1c)}
.admin-plan-limit-cell{min-width:120px;font-size:12px;font-weight:850;color:#334155;line-height:1.45}
.admin-plan-limit-cell b{font-weight:950;color:#111827}
.admin-plan-limit-mobile{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;margin:12px 0;background:#f8fafc;border:1px solid #e5e7eb;border-radius:12px;padding:12px}
.admin-plan-limit-mobile strong{grid-column:1/-1;font-size:14px;font-weight:950;color:#111827}
.admin-plan-limit-mobile span{font-size:13px;font-weight:850;color:#475569}
.admin-plan-limit-mobile b{color:#111827}

@media(max-width:700px){
  .billing-usage-grid{grid-template-columns:1fr}
  .billing-plan-name{align-items:flex-start;flex-direction:column}
  .billing-plan-name strong{font-size:25px}
  .admin-billing-request-list{grid-template-columns:1fr}
}

.billing-payment-box{display:flex;flex-direction:column;gap:12px;background:linear-gradient(145deg,#ffffff,#f8fafc);border:1px solid #dbeafe;border-radius:14px;padding:17px;box-shadow:0 14px 30px rgba(15,23,42,0.08)}
.billing-payment-title{font-size:17px;font-weight:950;color:#0f172a;line-height:1.45}
.billing-payment-row{display:grid;grid-template-columns:120px 1fr;gap:10px;align-items:center;background:#f8fafc;border:1px solid #e5e7eb;border-radius:12px;padding:13px}
.billing-payment-row span{font-size:14px;font-weight:950;color:#64748b}
.billing-payment-row strong{font-size:17px;font-weight:950;color:#111827;word-break:break-all}
.billing-payment-box p{margin:2px 0 0;color:#64748b;font-size:14px;line-height:1.6;font-weight:800}
@media(max-width:700px){.billing-payment-row{grid-template-columns:1fr;gap:5px}.billing-payment-row strong{font-size:16px}}

.billing-copy-row{cursor:pointer}
.billing-copy-btn{width:100%;display:flex;align-items:center;justify-content:space-between;gap:10px;border:0;background:transparent;padding:0;text-align:left;cursor:pointer}
.billing-copy-btn strong{font-size:17px;font-weight:950;color:#111827;word-break:break-all}
.billing-copy-btn em{min-width:48px;display:inline-flex;align-items:center;justify-content:center;border-radius:999px;background:#0f172a;color:#fff;font-style:normal;font-size:12px;font-weight:950;padding:7px 10px}
.billing-copy-row:hover{background:#eef2ff;border-color:#bfdbfe}
.billing-copy-result{display:none;margin-top:10px;background:#ecfdf5;border:1px solid #a7f3d0;color:#065f46;border-radius:10px;padding:10px 12px;font-size:14px;font-weight:900;line-height:1.45}
.billing-copy-result.show{display:block}
@media(max-width:700px){.billing-copy-btn{align-items:flex-start;flex-direction:column}.billing-copy-btn em{min-width:auto}}

.admin-user-search-box{margin:18px 0 16px;background:linear-gradient(145deg,#ffffff,#f8fafc);border:1px solid #dbeafe;border-radius:var(--radius);padding:15px;box-shadow:0 14px 30px rgba(15,23,42,0.08)}
.admin-user-search-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px}
.admin-user-search-head strong{font-size:18px;font-weight:950;color:#0f172a}
.admin-user-search-head span{display:inline-flex;align-items:center;justify-content:center;background:#eef2ff;color:#1e40af;border-radius:999px;padding:6px 10px;font-size:13px;font-weight:950;white-space:nowrap}
.admin-user-search-box input{width:100%;border:1px solid #cbd5e1;border-radius:var(--radius);background:#ffffff;padding:14px 15px;font-size:17px;font-weight:850;color:#0f172a;outline:none}
.admin-user-search-box input:focus{border-color:#60a5fa;box-shadow:0 0 0 4px rgba(96,165,250,0.18)}
.admin-user-search-guide{margin:8px 0 0;color:#64748b;font-size:13px;font-weight:800;line-height:1.45}
@media(max-width:700px){.admin-user-search-head{align-items:flex-start;flex-direction:column}.admin-user-search-box input{font-size:16px}}

.memo-account-transfer-btn{display:inline-flex;align-items:center;justify-content:center;margin:0 3px;padding:5px 9px;border:1px solid #bfdbfe;border-radius:999px;background:linear-gradient(135deg,#eff6ff,#ffffff);color:#1d4ed8;font-size:16px;font-weight:950;line-height:1.3;cursor:pointer;box-shadow:0 6px 14px rgba(37,99,235,0.12);vertical-align:baseline}
.memo-account-transfer-btn::before{content:"💸";margin-right:5px;font-size:13px}
.memo-account-transfer-btn:hover{background:linear-gradient(135deg,#dbeafe,#ffffff);border-color:#60a5fa;color:#1e3a8a}
.memo-bank-transfer-panel{position:fixed;left:0;right:0;bottom:0;z-index:9999;display:none;padding:16px;background:rgba(15,23,42,0.42);backdrop-filter:blur(6px)}
.memo-bank-transfer-panel.show{display:block}
.memo-bank-transfer-box{position:relative;max-width:520px;margin:0 auto;background:#ffffff;border:1px solid #dbeafe;border-radius:18px;padding:20px 18px 18px;box-shadow:0 24px 60px rgba(15,23,42,0.30)}
.memo-bank-transfer-box strong{display:block;margin:0 34px 8px 0;color:#0f172a;font-size:20px;font-weight:950}
.memo-bank-transfer-box p{margin:0 0 8px;color:#1d4ed8;font-size:18px;font-weight:950;word-break:break-all}
.memo-bank-transfer-box span{display:block;margin:0 0 14px;color:#64748b;font-size:14px;font-weight:850;line-height:1.45}
.memo-bank-transfer-close{position:absolute;right:12px;top:10px;width:34px;height:34px;border:0;border-radius:999px;background:#f1f5f9;color:#0f172a;font-size:24px;font-weight:900;line-height:1;cursor:pointer}
.memo-bank-recent{margin:0 0 14px;padding:11px;border:1px solid #bfdbfe;border-radius:12px;background:linear-gradient(145deg,#eff6ff,#ffffff)}
.memo-bank-recent em,.memo-bank-app-title{display:block;margin:0 0 7px;color:#64748b;font-size:12px;font-style:normal;font-weight:950}
.memo-bank-recent-btn{width:100%;min-height:58px!important;background:linear-gradient(135deg,#059669,#0f766e)!important;box-shadow:0 12px 24px rgba(5,150,105,0.22)!important}
.memo-bank-app-row{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.memo-bank-app-btn{display:flex;align-items:center;justify-content:space-between;gap:8px;min-height:46px;border:0;border-radius:10px;padding:10px 12px;background:linear-gradient(135deg,#0f172a,#2563eb);color:#fff;font-size:15px;font-weight:950;text-decoration:none;cursor:pointer;box-shadow:0 10px 22px rgba(37,99,235,0.20)}
.memo-bank-app-manual{background:linear-gradient(135deg,#475569,#334155);box-shadow:0 8px 18px rgba(51,65,85,0.18)}
.memo-bank-app-btn b{font-size:15px;font-weight:950}
.memo-bank-app-btn small{font-size:11px;font-weight:850;opacity:.82;white-space:nowrap}
@media(max-width:700px){.memo-account-transfer-btn{font-size:15px;padding:5px 8px}.memo-bank-transfer-panel{max-height:100vh;overflow-y:auto;padding:12px}.memo-bank-transfer-box{padding:18px 14px 15px}.memo-bank-app-row{grid-template-columns:1fr 1fr;gap:7px}.memo-bank-app-btn{min-height:48px;padding:9px 10px}.memo-bank-app-btn b{font-size:14px}.memo-bank-app-btn small{font-size:10px}}

.games-menu-card.tetris{border-color:rgba(59,130,246,0.48)}
.games-menu-card.tetris .games-menu-icon{background:linear-gradient(145deg,#eff6ff,#bfdbfe)}

.ai-pet-card{position:relative;overflow:visible;margin:0 0 22px;border:1px solid rgba(191,219,254,.72);border-radius:22px;background:radial-gradient(circle at 50% 34%,rgba(254,240,138,.30),transparent 34%),linear-gradient(145deg,#ffffff,#eef2ff);box-shadow:0 20px 44px rgba(15,23,42,.14),inset 0 1px 0 rgba(255,255,255,.88)}
.ai-pet-link{display:flex;flex-direction:column;align-items:stretch;text-decoration:none;color:#0f172a;padding:14px 22px 20px}
.ai-pet-character-zone{position:relative;display:flex;align-items:center;justify-content:center;min-height:306px}
.ai-pet-image-character{width:302px!important;height:302px!important}
.ai-pet-stage-image{max-height:302px}
.ai-pet-character-zone .pet-shadow{bottom:4px;width:196px;height:22px;background:rgba(15,23,42,.20)}
.ai-pet-info{position:relative;min-width:0;padding:4px 6px 2px}
.ai-pet-title-row{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:8px}
.ai-pet-title-row span{font-size:14px;font-weight:950;color:#64748b;letter-spacing:.5px}
.ai-pet-title-row b{border:1px solid rgba(15,23,42,.12);border-radius:999px;background:#111827;padding:6px 11px;color:#fff;font-size:14px;font-weight:950}
.ai-pet-info h2{display:inline-flex;margin:0 0 10px;border-radius:999px;background:#111827;padding:8px 14px;color:#fff;font-size:22px;font-weight:950;letter-spacing:-.6px}
.ai-pet-info p{margin:0;border:1px solid #dbeafe;border-radius:16px;background:#fff;padding:13px 14px;color:#0f172a;font-size:15px;font-weight:900;line-height:1.45;box-shadow:0 10px 22px rgba(15,23,42,.06)}
.ai-pet-info small{display:block;margin-top:8px;color:#64748b;font-size:12px;font-weight:800}
@media(max-width:700px){.ai-pet-card{margin-bottom:18px;border-radius:20px}.ai-pet-link{padding:8px 14px 16px}.ai-pet-character-zone{min-height:282px}.ai-pet-image-character{width:286px!important;height:286px!important}.ai-pet-stage-image{max-height:286px}.ai-pet-character-zone .pet-shadow{bottom:3px;width:180px;height:20px}.ai-pet-title-row span,.ai-pet-title-row b{font-size:12px}.ai-pet-info h2{font-size:19px}.ai-pet-info p{font-size:14px}.ai-pet-info small{display:none}}

.intro-login-link{position:relative;z-index:7;color:#bfdbfe;font-size:14px;font-weight:900;text-decoration:none}
.intro-login-link:hover{color:#fff;text-decoration:underline}
.guest-intro .intro-ai-title{font-size:38px!important}
.guest-intro .intro-simple-guide{max-width:330px}
.ai-register-panel{max-width:560px;margin:0 auto;padding:22px 26px 28px;background:radial-gradient(circle at 50% 0%,rgba(56,189,248,0.22),transparent 34%),linear-gradient(155deg,rgba(15,23,42,0.98),rgba(17,24,39,0.96));border-color:rgba(125,211,252,0.25);box-shadow:0 28px 70px rgba(2,6,23,0.35),inset 0 1px 0 rgba(255,255,255,0.08);color:#fff}
.register-ai-visual{position:relative;width:148px;height:148px;margin:0 auto 16px;display:flex;align-items:center;justify-content:center}
.register-ai-orbit{position:absolute;border-radius:999px;border:1px solid rgba(125,211,252,0.34);box-shadow:0 0 28px rgba(56,189,248,0.18)}
.register-ai-orbit.orbit-1{inset:8px;animation:introOrbitSpin 8s linear infinite}
.register-ai-orbit.orbit-2{inset:25px;border-style:dashed;animation:introOrbitSpin 11s linear infinite reverse}
.register-ai-bot{position:relative;width:86px;height:86px;border-radius:34% 40% 42% 36%;background:radial-gradient(circle at 34% 22%,#fff 0%,#dbeafe 20%,#60a5fa 45%,#2563eb 72%,#312e81 100%);box-shadow:0 0 22px rgba(125,211,252,0.95),0 0 60px rgba(59,130,246,0.52),inset 0 2px 16px rgba(255,255,255,0.58);animation:introAiFloat 3s ease-in-out infinite}
.register-ai-bot::before{content:"";position:absolute;left:50%;top:-22px;width:2px;height:22px;transform:translateX(-50%);background:linear-gradient(#e0f2fe,rgba(125,211,252,0.15))}
.register-ai-bot::after{content:"";position:absolute;left:50%;top:-30px;width:12px;height:12px;border-radius:999px;transform:translateX(-50%);background:#e0f2fe;box-shadow:0 0 18px rgba(125,211,252,0.95)}
.register-ai-eye{position:absolute;top:32px;width:12px;height:16px;border-radius:999px;background:linear-gradient(180deg,#e0f2fe,#38bdf8 55%,#0f172a)}
.register-ai-eye:first-child{left:27px}
.register-ai-eye:nth-child(2){right:27px}
.register-ai-core{position:absolute;left:50%;bottom:15px;width:18px;height:18px;border-radius:999px;transform:translateX(-50%);background:#67e8f9;box-shadow:0 0 18px rgba(103,232,249,0.95),0 0 34px rgba(37,99,235,0.76)}
.register-ai-copy{text-align:center;margin-top:-28px}
.register-ai-badge{display:inline-flex;align-items:center;justify-content:center;margin-bottom:10px;padding:7px 13px;border-radius:999px;background:rgba(14,165,233,0.16);border:1px solid rgba(125,211,252,0.28);color:#bfdbfe;font-size:12px;font-weight:950;letter-spacing:1px}
.ai-register-panel h1{margin-bottom:6px!important;color:#fff!important;font-size:30px!important;line-height:1.18!important;text-shadow:0 0 24px rgba(56,189,248,0.18)!important}
.ai-register-panel .desc{max-width:410px;margin:0 auto;color:#cbd5e1;font-size:15px;line-height:1.45}
.ai-register-form label{color:#dbeafe}
.ai-register-form input{border-color:rgba(125,211,252,0.28)!important;background:rgba(15,23,42,0.72)!important;color:#fff!important;box-shadow:inset 0 1px 0 rgba(255,255,255,0.08),0 14px 30px rgba(2,6,23,0.18)!important}
.ai-register-form input::placeholder{color:#94a3b8}
.ai-register-form input:focus{border-color:#67e8f9!important;box-shadow:0 0 0 4px rgba(103,232,249,0.15),0 18px 36px rgba(2,6,23,0.28)!important}
.ai-register-form .userid-check-btn{border-radius:14px;background:linear-gradient(135deg,#0891b2,#2563eb)}
.ai-register-submit{background:linear-gradient(135deg,#22c55e,#06b6d4,#2563eb)!important;box-shadow:0 18px 38px rgba(6,182,212,0.22);border-radius:18px!important}
.ai-register-panel .auth-link{color:#cbd5e1}
.ai-register-panel .auth-link a{color:#67e8f9}
.ai-login-panel{max-width:540px;margin:0 auto;padding:30px 26px 28px;background:radial-gradient(circle at 50% 0%,rgba(34,197,94,0.16),transparent 30%),radial-gradient(circle at 100% 20%,rgba(59,130,246,0.18),transparent 34%),linear-gradient(155deg,rgba(15,23,42,0.98),rgba(17,24,39,0.96));border-color:rgba(125,211,252,0.24);box-shadow:0 28px 70px rgba(2,6,23,0.35),inset 0 1px 0 rgba(255,255,255,0.08);color:#fff}
.login-ai-hero{text-align:center}
.ai-login-panel h1{color:#fff!important;text-shadow:0 0 24px rgba(56,189,248,0.18)!important}
.ai-login-panel .desc{color:#cbd5e1}
.ai-login-form label{color:#dbeafe}
.ai-login-form input{border-color:rgba(125,211,252,0.28)!important;background:rgba(15,23,42,0.72)!important;color:#fff!important;box-shadow:inset 0 1px 0 rgba(255,255,255,0.08),0 14px 30px rgba(2,6,23,0.18)!important}
.ai-login-form input::placeholder{color:#94a3b8}
.ai-login-form input:focus{border-color:#67e8f9!important;box-shadow:0 0 0 4px rgba(103,232,249,0.15),0 18px 36px rgba(2,6,23,0.28)!important}
.ai-login-options{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:2px}
.ai-login-options .remember-row{margin:0;padding:12px 13px;border:1px solid rgba(125,211,252,0.22);border-radius:14px;background:rgba(15,23,42,0.48);color:#dbeafe}
.ai-login-form .ai-voice-input-row,.ai-login-form .ai-voice-input-row.password-row{grid-template-columns:1fr!important}
.ai-login-options .remember-row,.ai-login-options .remember-row span{color:#ffffff!important}
.ai-auth-panel .remember-warning{margin:0;padding:12px 13px;border-radius:14px;background:rgba(15,23,42,0.48);border:1px solid rgba(251,191,36,0.22);color:#fde68a;font-size:13px;font-weight:800;line-height:1.45}
.ai-voice-input-row{display:grid;grid-template-columns:minmax(0,1fr) 52px;gap:9px;align-items:center}
.ai-voice-input-row:has(.ai-password-toggle){grid-template-columns:minmax(0,1fr) 52px 52px}
.ai-voice-input-row.password-row{grid-template-columns:minmax(0,1fr) 52px 52px}
.userid-check-row.ai-voice-input-row{grid-template-columns:minmax(0,1fr) 52px 108px}
.ai-field-mic{width:52px;height:52px;border:0;border-radius:16px;background:linear-gradient(135deg,#06b6d4,#2563eb);color:#fff;font-size:23px;font-weight:950;box-shadow:0 12px 24px rgba(6,182,212,0.2);cursor:pointer}
.ai-password-toggle{display:flex;align-items:center;justify-content:center;width:52px;height:52px;padding:0;border:1px solid rgba(125,211,252,0.28);border-radius:16px;background:rgba(15,23,42,0.64);color:#dbeafe;font-size:20px;font-weight:950;line-height:1;white-space:nowrap;cursor:pointer}
.ai-password-toggle:active{transform:scale(.96)}
.ai-field-mic:active{transform:scale(.96)}
.ai-auth-voice-status{width:100%!important;min-height:38px!important;padding:8px 12px!important;border-radius:14px!important;background:rgba(15,23,42,0.6)!important;color:#dbeafe!important;border:1px solid rgba(125,211,252,0.22)!important;font-size:13px!important;font-weight:900!important}
.ai-auth-panel .userid-check-result{display:block;margin-top:8px;padding:12px 14px;border-radius:14px;background:rgba(15,23,42,0.62);border:1px solid rgba(125,211,252,0.18);color:#dbeafe;font-size:14px;font-weight:950;line-height:1.35}
.ai-auth-panel .userid-check-result.success{background:#166534;border-color:#22c55e;color:#ffffff;text-shadow:none}
.ai-auth-panel .userid-check-result.error{background:#991b1b;border-color:#f87171;color:#ffffff;text-shadow:none}
.aisfor-guide-page{min-height:100vh;margin:-26px -18px -80px;padding:56px 18px 44px;background:radial-gradient(circle at 50% 4%,rgba(56,189,248,.34),transparent 28%),radial-gradient(circle at 16% 78%,rgba(168,85,247,.24),transparent 32%),linear-gradient(160deg,#020617,#07111f 52%,#111827);color:#fff}
.guide-orb{position:relative;width:118px;height:118px;margin:0 auto 18px;border-radius:34% 40% 42% 36%;background:radial-gradient(circle at 34% 22%,#fff,#dbeafe 22%,#60a5fa 48%,#2563eb 76%,#312e81);box-shadow:0 0 34px rgba(125,211,252,.9),0 0 90px rgba(59,130,246,.44);animation:introAiFloat 3s ease-in-out infinite}
.guide-orb span{position:absolute;left:50%;bottom:18px;width:22px;height:22px;border-radius:999px;transform:translateX(-50%);background:#67e8f9;box-shadow:0 0 22px rgba(103,232,249,.95)}
.guide-orb::before{content:"";position:absolute;left:34px;top:48px;width:14px;height:18px;border-radius:999px;background:linear-gradient(180deg,#e0f2fe,#38bdf8 50%,#0f172a);box-shadow:36px 0 0 #0f172a,0 0 14px rgba(56,189,248,.8),36px 0 14px rgba(56,189,248,.5)}
.guide-orb::after{content:"";position:absolute;left:50%;top:77px;width:30px;height:12px;border-bottom:4px solid rgba(15,23,42,.86);border-radius:0 0 999px 999px;transform:translateX(-50%)}
.guide-character-zone{margin:-8px auto 10px;width:230px;height:230px}
.auth-character-zone{margin:-22px auto 0;width:250px;height:250px;transform:scale(.58);transform-origin:center}
@media(max-width:700px){.auth-character-zone{width:220px;height:220px;margin:-26px auto -12px;transform:scale(.52)}}
.guide-hero{max-width:780px;margin:0 auto;text-align:center}
.guide-badge{display:inline-flex;padding:8px 15px;border:1px solid rgba(125,211,252,.32);border-radius:999px;background:rgba(14,165,233,.16);color:#bfdbfe;font-size:12px;font-weight:950;letter-spacing:1px}
.guide-hero h1{margin:14px 0 10px;font-size:32px;line-height:1.18;font-weight:950;letter-spacing:0}
.guide-hero p{margin:0 auto;max-width:640px;color:#cbd5e1;font-size:17px;font-weight:800;line-height:1.6}
.guide-actions{display:flex;justify-content:center;gap:10px;flex-wrap:wrap;margin-top:22px}
.guide-actions a{display:inline-flex;align-items:center;justify-content:center;min-height:50px;padding:13px 22px;border-radius:999px;background:linear-gradient(135deg,#22c55e,#06b6d4,#2563eb);color:#fff;text-decoration:none;font-weight:950}
.guide-actions a.ghost{background:rgba(15,23,42,.72);border:1px solid rgba(125,211,252,.28)}
.guide-grid{max-width:960px;margin:34px auto 0;display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.guide-grid article{min-height:154px;padding:18px;border:1px solid rgba(125,211,252,.22);border-radius:18px;background:rgba(15,23,42,.66);box-shadow:0 18px 40px rgba(2,6,23,.24)}
.guide-grid b{display:block;margin-bottom:10px;font-size:18px}
.guide-grid p{margin:0;color:#dbeafe;font-size:14px;font-weight:800;line-height:1.55}
.guide-script{max-width:760px;margin:22px auto 0;padding:20px;border-radius:20px;background:rgba(103,232,249,.1);border:1px solid rgba(103,232,249,.22);text-align:center}
.guide-script h2{margin:0 0 8px;font-size:22px}
.guide-script p{margin:0;color:#e0f2fe;font-weight:900;line-height:1.6}
@media(max-width:900px){.guide-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:620px){.aisfor-guide-page{padding:28px 14px}.guide-character-zone{width:210px;height:210px;margin:-14px auto 4px}.guide-hero h1{font-size:25px}.guide-hero p{font-size:15px}.guide-grid{grid-template-columns:1fr}.guide-grid article{min-height:auto}.guide-actions a{width:100%}}
@media(max-width:700px){.guest-intro .intro-ai-title{font-size:25px!important}.ai-register-panel{padding:24px 18px}.register-ai-visual{width:124px;height:124px;margin-bottom:10px}.register-ai-bot{width:74px;height:74px}.register-ai-eye{top:28px}.register-ai-eye:first-child{left:23px}.register-ai-eye:nth-child(2){right:23px}}
@media(max-width:700px){.ai-login-panel{padding:24px 18px}.userid-check-row.ai-voice-input-row{grid-template-columns:minmax(0,1fr) 48px}.userid-check-row.ai-voice-input-row .userid-check-btn{grid-column:1 / -1;width:100%;min-height:46px}.ai-voice-input-row{grid-template-columns:minmax(0,1fr) 48px}.ai-field-mic{width:48px;height:48px;border-radius:14px}.ai-login-options{grid-template-columns:1fr}}

.english-learning-page{width:min(100%,1080px);margin:0 auto;padding:18px 14px 44px;color:#0f172a}
.english-learning-hero{border:1px solid rgba(148,163,184,.35);border-radius:24px;padding:24px;background:linear-gradient(145deg,#f8fafc,#e0f2fe);box-shadow:0 18px 42px rgba(15,23,42,.14)}
.english-learning-hero span,.english-reading-head span{display:block;margin-bottom:8px;color:#2563eb;font-size:13px;font-weight:950;letter-spacing:0}
.english-learning-hero h1,.english-reading-head h1{margin:0;color:#0f172a;font-size:clamp(34px,8vw,54px);line-height:1.05;font-weight:1000;letter-spacing:0}
.english-learning-hero p,.english-reading-head p{margin:12px 0 0;color:#475569;font-size:17px;font-weight:850;line-height:1.5}
.english-learning-menu{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin-top:16px}
.english-learning-menu.compact{grid-template-columns:repeat(4,minmax(0,1fr))}
.english-learning-card{display:flex;flex-direction:column;justify-content:space-between;min-height:154px;border:1px solid rgba(148,163,184,.34);border-radius:22px;padding:20px;background:linear-gradient(145deg,#fff,#eef2ff);color:#0f172a;text-decoration:none;box-shadow:0 16px 36px rgba(15,23,42,.12)}
.english-learning-card.primary{background:linear-gradient(135deg,#0f172a,#1d4ed8);color:#fff}
.english-learning-card span{font-size:34px;line-height:1}
.english-learning-card strong{display:block;margin-top:16px;font-size:27px;line-height:1.12;font-weight:1000}
.english-learning-card small{display:block;margin-top:8px;color:#64748b;font-size:15px;font-weight:900;line-height:1.35}
.english-learning-card.primary small{color:#dbeafe}
.english-learning-note{margin-top:16px;border-radius:18px;padding:16px 18px;background:#111827;color:#fff;font-weight:950}
.english-reading-head{display:flex;align-items:flex-start;gap:14px;margin-bottom:16px}
.english-small-btn{flex:0 0 auto;display:inline-flex;align-items:center;justify-content:center;min-height:46px;border-radius:999px;padding:10px 15px;background:#111827;color:#fff;text-decoration:none;font-weight:950}
.english-reading-panel{margin-top:16px;border:1px solid rgba(148,163,184,.34);border-radius:22px;padding:18px;background:linear-gradient(145deg,#f8fafc,#eef2ff);box-shadow:0 16px 36px rgba(15,23,42,.12)}
.english-section-row{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px}
.english-section-row h2{margin:0;color:#111827;font-size:24px;font-weight:1000}
.english-section-row b{border-radius:999px;padding:8px 11px;background:#dbeafe;color:#1d4ed8;font-size:14px;font-weight:950;white-space:nowrap}
.english-book-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:12px}
.english-book-grid.advanced{grid-template-columns:repeat(auto-fit,minmax(230px,1fr))}
.english-book-card{display:block;min-height:132px;border:1px solid rgba(148,163,184,.3);border-radius:18px;padding:16px;background:#fff;color:#0f172a;text-decoration:none;box-shadow:inset 0 0 0 1px rgba(255,255,255,.5)}
.english-book-card span{display:inline-flex;margin-bottom:10px;border-radius:999px;padding:6px 10px;background:#dbeafe;color:#1d4ed8;font-size:13px;font-weight:950}
.english-book-card strong{display:block;color:#111827;font-size:20px;font-weight:1000;line-height:1.2}
.english-book-card small{display:block;margin-top:8px;color:#64748b;font-size:14px;font-weight:850;line-height:1.35}
.english-book-card.locked{background:#e5e7eb;color:#94a3b8;box-shadow:none}
.english-book-card.locked strong,.english-book-card.locked small{color:#94a3b8}
.english-original-box{max-height:360px;overflow:auto;border-radius:16px;padding:16px;background:#fff;color:#334155;font-size:16px;font-weight:800;line-height:1.65;white-space:pre-wrap}
.english-empty-reading{border-radius:16px;padding:20px;background:#fff;color:#64748b;font-size:17px;font-weight:950;text-align:center}
.english-empty-reading.large{padding:46px 20px;font-size:22px}
.english-reading-stage-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
.english-reading-stage{display:flex;align-items:center;justify-content:space-between;gap:10px;min-height:70px;border-radius:16px;padding:14px;background:#fff;color:#0f172a;text-decoration:none;font-weight:950;box-shadow:inset 0 0 0 1px rgba(148,163,184,.24)}
.english-reading-stage span{font-size:22px}
.english-reading-stage strong{font-size:18px}
.english-reading-stage small{color:#64748b;font-size:13px;font-weight:900;text-align:right}
.english-reading-stage.ready{background:#ecfdf5}
.english-reading-stage.pending{background:#fff7ed}
.english-reading-stage.locked{background:#e5e7eb;color:#94a3b8}
.english-unit-list{display:grid;gap:12px}
.english-unit-card{border-radius:18px;padding:16px;background:#fff;box-shadow:inset 0 0 0 1px rgba(148,163,184,.24)}
.english-unit-card span{display:block;margin-bottom:8px;color:#2563eb;font-size:13px;font-weight:950}
.english-unit-card strong{display:block;color:#111827;font-size:20px;font-weight:1000;line-height:1.45}
.english-unit-card p{margin:10px 0 0;color:#475569;font-size:16px;font-weight:850;line-height:1.5}
.english-unit-card em{display:block;margin-top:10px;color:#64748b;font-style:normal;font-weight:850;line-height:1.45}
.english-original-details summary{display:flex;align-items:center;justify-content:space-between;min-height:48px;border-radius:14px;padding:12px 14px;background:#111827;color:#fff;font-size:17px;font-weight:950;cursor:pointer}
.english-original-details summary::after{content:"펼치기";font-size:13px;color:#bfdbfe}
.english-original-details[open] summary::after{content:"접기"}
.english-original-details .english-original-box,.english-original-details .english-empty-reading{margin-top:12px}
.english-translate-panel{max-width:780px;margin-left:auto;margin-right:auto}
.english-reading-question-card{border-radius:20px;padding:18px;background:#fff;box-shadow:inset 0 0 0 1px rgba(148,163,184,.25)}
.english-reading-question-card span{display:block;margin-bottom:10px;color:#2563eb;font-size:14px;font-weight:950}
.english-reading-question-card strong{display:block;color:#111827;font-size:clamp(24px,7vw,38px);font-weight:1000;line-height:1.28}
.english-reading-question-card label{display:block;margin-top:18px;margin-bottom:8px;color:#334155;font-size:15px;font-weight:950}
.english-reading-question-card textarea{width:100%;min-height:128px;box-sizing:border-box;border:1px solid rgba(148,163,184,.45);border-radius:16px;padding:14px 15px;background:#f8fafc;color:#111827;font:inherit;font-size:18px;font-weight:850;line-height:1.45;resize:vertical}
.english-reading-question-card textarea:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 4px rgba(37,99,235,.14);background:#fff}
.english-reading-answer-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:12px}
.english-reading-answer-actions button{min-height:54px;border:0;border-radius:16px;background:linear-gradient(135deg,#2563eb,#7c3aed);color:#fff;font:inherit;font-size:17px;font-weight:1000;cursor:pointer}
.english-reading-answer-actions button.voice{background:linear-gradient(135deg,#0f766e,#06b6d4)}
.english-reading-answer-actions button.voice.listening{background:linear-gradient(135deg,#dc2626,#f97316)}
.english-reading-answer-actions button[hidden]{display:none}
.english-reading-answer-actions button:disabled{opacity:.6;cursor:default}.english-reading-complete-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:14px}
.english-reading-complete-actions a{min-height:54px;border-radius:16px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#2563eb,#7c3aed);color:#fff;text-decoration:none;font-size:17px;font-weight:1000}
.english-reading-complete-actions a.secondary{background:#fff;color:#064e3b;box-shadow:inset 0 0 0 1px rgba(6,78,59,.25)}.english-reading-complete-actions a.disabled{opacity:.55;pointer-events:none;cursor:default}
#readingNextBtn{background:linear-gradient(135deg,#059669,#06b6d4)}
.english-reading-feedback{margin-top:14px;border-radius:18px;padding:16px 18px;font-size:16px;font-weight:850;line-height:1.55}
.english-reading-feedback strong{display:block;margin-bottom:8px;font-size:20px;font-weight:1000}
.english-reading-feedback p{margin:10px 0 0}
.english-reading-feedback.correct{background:#dcfce7;color:#064e3b}
.english-reading-feedback.wrong{background:#fee2e2;color:#7f1d1d}
.english-reading-vocab{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px}
.english-reading-vocab span{display:inline-flex;gap:5px;border-radius:999px;padding:7px 10px;background:rgba(255,255,255,.72);font-size:14px;font-weight:900}
.english-life-summary{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin-top:16px}
.english-life-summary article{border-radius:18px;padding:16px;background:linear-gradient(135deg,#111827,#1d4ed8);color:#fff;box-shadow:0 14px 30px rgba(15,23,42,.18)}
.english-life-summary span{display:block;margin-bottom:8px;color:#bfdbfe;font-weight:950}
.english-life-summary strong{display:block;font-size:24px;font-weight:1000}
.english-life-level-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:10px;margin-top:16px}
.english-life-level-card{display:block;min-height:112px;border-radius:18px;padding:15px;background:#fff;color:#0f172a;text-decoration:none;box-shadow:inset 0 0 0 1px rgba(148,163,184,.28),0 12px 26px rgba(15,23,42,.1)}
.english-life-level-card span{display:block;color:#2563eb;font-weight:950}
.english-life-level-card strong{display:block;margin-top:12px;font-size:24px;font-weight:1000}
.english-life-level-card small{display:block;margin-top:8px;color:#64748b;font-weight:850}
.english-life-level-card.locked{background:#e5e7eb;color:#94a3b8;box-shadow:none}
.english-life-level-card.locked span,.english-life-level-card.locked small{color:#94a3b8}
.english-life-step-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:12px}
.english-life-step-card{display:block;min-height:142px;border-radius:18px;padding:16px;background:#fff;color:#0f172a;text-decoration:none;box-shadow:inset 0 0 0 1px rgba(148,163,184,.28),0 12px 26px rgba(15,23,42,.1)}
.english-life-step-card span{display:inline-flex;margin-bottom:10px;border-radius:999px;padding:6px 10px;background:#dbeafe;color:#1d4ed8;font-weight:950}
.english-life-step-card strong{display:block;color:#111827;font-size:20px;font-weight:1000;line-height:1.25}
.english-life-step-card small{display:block;margin-top:8px;color:#64748b;font-weight:850;line-height:1.45}
.english-life-step-card.cleared{background:#ecfdf5}
.english-life-step-card.locked{background:#e5e7eb;box-shadow:none}
.english-life-step-card.locked strong,.english-life-step-card.locked small{color:#94a3b8}
.english-life-expression-list,.english-life-dialogue-list{display:grid;gap:10px}
.english-life-expression,.english-life-dialogue{display:flex;gap:12px;border-radius:16px;padding:14px;background:#fff;box-shadow:inset 0 0 0 1px rgba(148,163,184,.24)}
.english-life-expression strong,.english-life-dialogue strong{display:block;color:#111827;font-size:20px;font-weight:1000;line-height:1.3}
.english-life-expression p,.english-life-dialogue p{margin:7px 0 0;color:#475569;font-weight:850;line-height:1.45}
.english-life-expression em{display:block;margin-top:7px;color:#64748b;font-style:normal;font-weight:850;line-height:1.4}
.english-life-dialogue>span{display:flex;align-items:center;justify-content:center;flex:0 0 42px;height:42px;border-radius:999px;background:#111827;color:#fff;font-weight:1000}
.english-life-speak{flex:0 0 auto;width:42px;height:42px;border:0;border-radius:999px;background:linear-gradient(135deg,#2563eb,#06b6d4);color:#fff;font-size:18px;font-weight:1000;cursor:pointer}
.english-life-mission-card{border-radius:20px;padding:18px;background:#fff;box-shadow:inset 0 0 0 1px rgba(148,163,184,.25)}
.english-life-mission-card>span{display:block;margin-bottom:10px;color:#2563eb;font-weight:950}
.english-life-mission-card>strong{display:block;color:#111827;font-size:clamp(22px,6vw,34px);font-weight:1000;line-height:1.3}
.english-life-speak-input-row{display:grid;grid-template-columns:minmax(0,1fr);gap:10px;align-items:center;margin-top:14px}
.english-life-speak-input-row.speaking{grid-template-columns:minmax(0,1fr) 56px 56px}
.english-life-mission-card textarea{width:100%;min-height:104px;box-sizing:border-box;border:1px solid rgba(148,163,184,.45);border-radius:16px;padding:14px 15px;background:#f8fafc;color:#111827;font:inherit;font-size:17px;font-weight:850;line-height:1.45;resize:vertical}
.english-life-mission-card textarea:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 4px rgba(37,99,235,.14);background:#fff}
.english-life-mic-btn{width:56px;height:56px;border:0;border-radius:16px;background:linear-gradient(135deg,#06b6d4,#2563eb);color:#fff;font-size:22px;font-weight:1000;cursor:pointer}
.english-life-mic-btn.stop{background:#111827}
.english-life-mic-btn[hidden]{display:none}
.english-life-choice-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-top:16px}
.english-life-choice-grid button{min-height:52px;border:0;border-radius:14px;padding:12px;background:#e0f2fe;color:#0f172a;font:inherit;font-weight:950;cursor:pointer}
.english-life-choice-grid button.selected{background:#2563eb;color:#fff}
.english-life-choice-grid button:disabled{opacity:.55;cursor:default}
.english-life-order-box{margin-top:12px;border-radius:14px;padding:12px;background:#f8fafc;color:#334155;font-weight:950;line-height:1.4}
.english-life-next-lesson-btn{display:flex;align-items:center;justify-content:center;min-height:56px;margin-top:14px;border-radius:16px;background:linear-gradient(135deg,#059669,#06b6d4);color:#fff;text-decoration:none;font-size:18px;font-weight:1000;box-shadow:0 14px 28px rgba(6,182,212,.22)}
.english-grammar-summary{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin-top:16px}
.english-grammar-summary article{border-radius:18px;padding:16px;background:linear-gradient(135deg,#111827,#4f46e5);color:#fff;box-shadow:0 14px 30px rgba(15,23,42,.18)}
.english-grammar-summary span{display:block;margin-bottom:8px;color:#c7d2fe;font-weight:950}
.english-grammar-summary strong{display:block;font-size:24px;font-weight:1000}
.english-grammar-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:12px}
.english-grammar-card{display:block;min-height:146px;border-radius:18px;padding:16px;background:#fff;color:#0f172a;text-decoration:none;box-shadow:inset 0 0 0 1px rgba(148,163,184,.28),0 12px 26px rgba(15,23,42,.1)}
.english-grammar-card span{display:inline-flex;margin-bottom:10px;border-radius:999px;padding:6px 10px;background:#e0e7ff;color:#3730a3;font-size:13px;font-weight:950}
.english-grammar-card strong{display:block;color:#111827;font-size:21px;font-weight:1000;line-height:1.25}
.english-grammar-card small{display:block;margin-top:8px;color:#64748b;font-size:14px;font-weight:850;line-height:1.45}
.english-grammar-rule{border-radius:16px;padding:18px;background:#fff;color:#111827;font-size:18px;font-weight:900;line-height:1.65;box-shadow:inset 0 0 0 1px rgba(148,163,184,.24)}
.english-grammar-patterns{display:flex;flex-wrap:wrap;gap:10px}
.english-grammar-patterns span{display:inline-flex;border-radius:999px;padding:10px 13px;background:#111827;color:#fff;font-size:15px;font-weight:950}
.english-grammar-example-list{display:grid;gap:12px}
.english-grammar-example{border-radius:18px;padding:16px;background:#fff;box-shadow:inset 0 0 0 1px rgba(148,163,184,.24)}
.english-grammar-example span{display:block;margin-bottom:8px;color:#4f46e5;font-size:13px;font-weight:950}
.english-grammar-example strong{display:block;color:#111827;font-size:22px;font-weight:1000;line-height:1.35}
.english-grammar-example p{margin:8px 0 0;color:#334155;font-size:17px;font-weight:900;line-height:1.5}
.english-grammar-example em{display:block;margin-top:8px;color:#64748b;font-style:normal;font-size:14px;font-weight:850;line-height:1.45}
.english-grammar-mistakes{display:grid;gap:10px}
.english-grammar-mistakes p{margin:0;border-radius:14px;padding:14px;background:#fff7ed;color:#7c2d12;font-size:16px;font-weight:900;line-height:1.45}
.english-grammar-test-list{display:grid;gap:12px}
.english-grammar-test{border-radius:18px;padding:16px;background:#fff;box-shadow:inset 0 0 0 1px rgba(148,163,184,.24)}
.english-grammar-test>span{display:block;margin-bottom:8px;color:#4f46e5;font-size:13px;font-weight:950}
.english-grammar-test>strong{display:block;color:#111827;font-size:20px;font-weight:1000;line-height:1.35}
.english-grammar-test-choices{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-top:14px}
.english-grammar-test-choices button{min-height:50px;border:0;border-radius:14px;padding:11px 12px;background:#e0e7ff;color:#111827;font:inherit;font-size:16px;font-weight:950;cursor:pointer}
.english-grammar-test-choices button.correct{background:#16a34a;color:#fff}
.english-grammar-test-choices button.wrong{background:#dc2626;color:#fff}
.english-grammar-test-choices button:disabled{cursor:default;opacity:.92}
.english-grammar-test-result{margin:12px 0 0;border-radius:14px;padding:13px 14px;font-size:15px;font-weight:900;line-height:1.45}
.english-grammar-test-result b{display:block;margin-bottom:5px}
.english-grammar-test-result em{display:block;color:inherit;font-style:normal}
.english-grammar-test-result.correct{background:#dcfce7;color:#064e3b}
.english-grammar-test-result.wrong{background:#fee2e2;color:#7f1d1d}
.english-grammar-nav{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-top:16px}
.english-grammar-nav a{display:flex;align-items:center;justify-content:center;min-height:54px;border-radius:16px;background:linear-gradient(135deg,#2563eb,#7c3aed);color:#fff;text-decoration:none;font-size:17px;font-weight:1000}
@media(max-width:720px){.english-learning-menu,.english-learning-menu.compact{grid-template-columns:1fr}.english-reading-head{flex-direction:column}.english-section-row{align-items:flex-start;flex-direction:column}.english-reading-stage-grid{grid-template-columns:1fr}.english-reading-stage{align-items:flex-start;flex-direction:column}.english-reading-stage small{text-align:left}}
@media(max-width:720px){.english-life-summary,.english-grammar-summary{grid-template-columns:1fr}.english-life-choice-grid,.english-grammar-test-choices{grid-template-columns:1fr}.english-life-expression,.english-life-dialogue{align-items:flex-start}.english-life-step-grid{grid-template-columns:1fr}.english-grammar-nav{grid-template-columns:1fr}}
@media(max-width:720px){.english-reading-answer-actions,.english-reading-complete-actions{grid-template-columns:1fr}.english-reading-question-card{padding:15px}.english-reading-question-card textarea{font-size:16px}}

.login-ai-hero .login-intro-character-zone{margin:0 auto 18px;width:220px;height:220px}
.login-ai-hero .login-intro-character-zone .intro-character{width:128px;height:128px}
.login-ai-hero .login-intro-character-zone .intro-face{top:44px}
.login-ai-hero .login-intro-character-zone .intro-mouth{top:80px}
.login-ai-hero .login-intro-character-zone .intro-core{bottom:15px}

.intro-app-action-row{display:flex;justify-content:center;align-items:center;gap:10px;margin-top:12px;flex-wrap:wrap}
.intro-app-action-btn{display:inline-flex;align-items:center;justify-content:center;min-width:132px;min-height:38px;padding:10px 14px;border-radius:999px;background:rgba(255,255,255,0.14);border:1px solid rgba(255,255,255,0.28);color:#fff;text-decoration:none;font-size:14px;font-weight:900;box-shadow:0 10px 22px rgba(0,0,0,0.18)}
.intro-app-action-btn.install{background:linear-gradient(135deg,#2563eb,#7c3aed);border-color:rgba(255,255,255,0.34)}
.intro-app-action-btn:hover{transform:translateY(-1px);background:rgba(255,255,255,0.22)}
