:root{--bg: #f7f6f2;--surface: #ffffff;--surface2: #f0efe9;--border: #e2e0d6;--border2: #ccc9b8;--text: #1a1917;--text2: #6b6860;--text3: #9e9b8f;--green: #1f6a4e;--green-2: #0e4a37;--green-dark: #0c3a2d;--red: #b5360f;--red-bg: #fceee8;--radius: 10px;font-family:Noto Sans KR,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:var(--text);background:var(--bg)}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{background:var(--bg)}img{display:block}.loginScreen{min-height:100%;position:relative;display:flex;align-items:center;justify-content:center;padding:110px 24px 36px;background:radial-gradient(circle at 14% 72%,rgba(31,106,78,.06),transparent 26%),radial-gradient(circle at 86% 70%,rgba(31,106,78,.05),transparent 24%),linear-gradient(180deg,#fcfdfc,#f6f7f5);overflow:hidden}.loginHeroBar{position:absolute;inset:0 0 auto;height:92px;background:linear-gradient(90deg,#0d4332,#0d6048 52%,#0b4937);box-shadow:0 10px 32px #0a34262e}.loginHeroBrand{height:100%;display:flex;align-items:center;gap:14px;padding:0 34px;color:#fff;font-size:25px;font-weight:700;letter-spacing:-.02em}.heroBrandIcon,.loginBrandIcon,.brandIcon{width:48px;height:48px;object-fit:contain}.loginCard{width:min(470px,100%);background:#fffffff5;border:1px solid rgba(222,226,220,.95);border-radius:26px;padding:34px 46px 38px;box-shadow:0 18px 60px #0000001a;position:relative;z-index:1}.loginCardPremium:before,.loginCardPremium:after{content:"";position:absolute;width:260px;height:260px;border-radius:50%;pointer-events:none}.loginCardPremium:before{right:-170px;top:-120px;background:radial-gradient(circle,#1f6a4e1a,#1f6a4e00 72%)}.loginCardPremium:after{left:-190px;bottom:-160px;background:radial-gradient(circle,#1f6a4e0f,#1f6a4e00 72%)}.loginBrand{display:flex;gap:12px;align-items:center;margin-bottom:14px}.loginBrand.centered{justify-content:center;margin-bottom:18px}.loginLogoText{font-size:16px;font-weight:700}.loginSub{font-size:11px;color:var(--text3);margin-top:2px}.loginCard h1{font-size:34px;line-height:1.15;margin:0 0 8px;text-align:center;letter-spacing:-.03em}.loginDesc{color:#6f726d;font-size:15px;margin:0 0 28px;text-align:center}.fieldLabel{display:block;font-size:12px;color:var(--text2);font-weight:600;margin:16px 0 6px}.loginCard input,.loginCard select{width:100%;height:48px;border:1px solid #d9ddd4;border-radius:13px;padding:0 14px;font-size:15px;background:#fffffff5;color:var(--text)}.loginCard input:focus,.loginCard select:focus{outline:none;border-color:var(--green);box-shadow:0 0 0 4px #1f6a4e1a}.primaryButton{width:100%;height:50px;margin-top:20px;border:none;border-radius:13px;background:linear-gradient(90deg,#0d4332,#0f6f52);color:#fff;font-weight:700;font-size:16px;cursor:pointer;box-shadow:0 10px 24px #0f5c452e}.primaryButton:disabled{opacity:.55;cursor:not-allowed}.errorBox{display:none;margin-top:12px;background:var(--red-bg);color:var(--red);border:1px solid #e8c0b0;border-radius:var(--radius);padding:9px 11px;font-size:12px;line-height:1.5}.errorBox.visible{display:block}.loginFoot{margin-top:20px;color:#8c9088;font-size:13px;text-align:center;line-height:1.7}.centerState{height:100%;display:grid;place-items:center;color:var(--text2)}.globalError,.shellError{position:fixed;left:50%;bottom:20px;transform:translate(-50%);max-width:min(720px,calc(100% - 32px));background:var(--red-bg);color:var(--red);border:1px solid #e8c0b0;border-radius:var(--radius);padding:10px 14px;font-size:13px;z-index:100}.appShell{height:100%;display:flex;flex-direction:column;overflow:hidden}.topbar{height:64px;display:flex;align-items:center;gap:12px;padding:0 18px;background:linear-gradient(90deg,#0d4332,#0d6048 52%,#0b4937);border-bottom:1px solid rgba(255,255,255,.08);color:#fff;flex-shrink:0}.brandLockup{display:flex;align-items:center;gap:12px}.brandText{display:flex;flex-direction:column;line-height:1.2}.brandText.singleLine{display:block}.brandText strong{font-size:14px;color:#fff}.brandText span{color:#ffffffb8;font-size:11px}.topbarSpacer{flex:1}.statusPill,.userPill{border-radius:999px;background:#ffffff1f;color:#ffffffeb;padding:6px 11px;font-size:12px;white-space:nowrap}.ghostButton,.smallButton{border:1px solid var(--border2);background:var(--surface);color:var(--text);border-radius:8px;padding:6px 11px;cursor:pointer;font-size:12px}.headerLogout{border-color:#ffffff47;background:transparent;color:#fff}.ghostButton:hover,.smallButton:hover{background:var(--surface2)}.previewNotice{min-height:38px;display:flex;align-items:center;gap:10px;flex-wrap:wrap;padding:7px 18px;background:#fbfdfb;border-bottom:1px solid #b8d8c0;color:var(--green-dark);font-size:12px;flex-shrink:0}.previewNotice span{color:var(--text2)}.legacyFrame{flex:1;width:100%;height:100%;border:0;background:var(--bg)}@media (max-width: 760px){.topbar{height:auto;min-height:54px;flex-wrap:wrap;padding:10px 14px}.previewNotice{align-items:flex-start}.loginScreen{padding-top:96px}.loginHeroBar{height:74px}.loginHeroBrand{padding:0 18px;font-size:22px}.heroBrandIcon{width:42px;height:42px}.loginCard{padding:30px 22px 28px;border-radius:20px}.loginCard h1{font-size:30px}}.frameWrap{flex:1;position:relative;min-height:0;background:var(--bg)}.frameOverlay{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;align-content:center;gap:8px;color:var(--text2);font-size:14px;background:var(--bg);z-index:2}.frameOverlay span{font-size:12px;color:var(--text3)}.legacyFrameHidden{visibility:hidden}.bottomStatusArea{flex-shrink:0;max-height:42vh;overflow:auto;padding:10px 0 12px;background:var(--bg);border-top:1px solid var(--border)}.bottomStatusArea .previewNotice{min-height:auto;margin:0 18px 8px;padding:8px 12px;border:1px solid var(--border);border-radius:var(--radius);background:#fbfdfb;box-shadow:0 1px 2px #0000000a}.bottomStatusArea .lastSaveNotice{font-size:11px;color:var(--text3);background:var(--surface)}.buildMeta{margin-left:auto;color:var(--text3)!important;font-size:10px;opacity:.72}@media (max-width: 760px){.bottomStatusArea{max-height:50vh}}.copyrightText{margin-top:10px;color:var(--text3);font-size:10.5px;line-height:1.5;letter-spacing:.01em}.shellCopyright{margin:2px 18px 0;text-align:right}:root{--bg: #f4f8ff;--surface: #ffffff;--surface2: #eef5ff;--border: #d7e1f1;--border2: #c9d8ee;--text: #17233a;--text2: #667085;--text3: #98a2b3;--green: #2c63f6;--green-2: #1e56e8;--green-dark: #164194;--red: #e5484d;--red-bg: #fff1f2}body{background:linear-gradient(rgba(23,35,58,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(23,35,58,.04) 1px,transparent 1px),linear-gradient(180deg,#f8fbff,#eef4ff);background-size:44px 44px,44px 44px,auto}.loginScreen{padding:44px 24px 36px;background:linear-gradient(rgba(23,35,58,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(23,35,58,.04) 1px,transparent 1px),radial-gradient(circle at 12% 12%,rgba(44,99,246,.1),transparent 30%),linear-gradient(180deg,#f8fbff,#eef4ff);background-size:44px 44px,44px 44px,auto,auto}.loginHeroBar{display:none}.loginCard{width:min(620px,100%);border:1px solid #d7e1f1;border-radius:34px;padding:54px 48px 42px;box-shadow:0 28px 90px #0f23501f;background:#fffffff5}.loginCardPremium:before,.loginCardPremium:after{display:none}.loginBrand.centered{margin-bottom:30px}.loginBrandIcon.ciFullLogo{width:240px;height:auto;max-height:76px;object-fit:contain}.loginCard h1{font-size:56px;margin-bottom:18px;color:#15203a;font-weight:800;letter-spacing:-.06em}.loginDesc{color:#667085;font-size:17px;line-height:1.75;margin-bottom:38px}.fieldLabel{color:#4b5563;font-weight:800}.loginCard input,.loginCard select{height:58px;border-color:#c9d8ee;border-radius:18px;font-size:16px;color:#17233a}.loginCard input:focus,.loginCard select:focus{border-color:#2c63f6c7;box-shadow:0 0 0 4px #2c63f61f}.primaryButton{height:58px;border-radius:18px;background:linear-gradient(135deg,#2c63f6,#1e56e8);box-shadow:0 18px 34px #2c63f640;font-weight:800}.loginFoot{color:#98a2b3}.copyrightText{color:#a3adbd}.topbar{background:#fff;border-bottom:1px solid #d7e1f1;color:#17233a;box-shadow:0 4px 16px #0f23500a}.brandIcon{width:42px;height:42px;padding:3px;border:1px solid #d7e1f1;border-radius:12px;background:#fff}.brandText strong{color:#17233a;font-size:17px}.brandText span{color:#667085}.statusPill,.userPill{background:#eef5ff;color:#2b5bbe;border:1px solid #d5e5ff}.headerLogout{border-color:#c9d8ee;background:#fff;color:#31415c}.headerLogout:hover{background:#eef5ff}.previewNotice{background:#fff;border-bottom:1px solid #d5e5ff;color:#164194}.previewNotice span{color:#667085}.frameWrap,.legacyFrame,.frameOverlay,.bottomStatusArea{background:#f4f8ff}.bottomStatusArea .previewNotice{border-color:#d7e1f1;background:#fff}.ghostButton,.smallButton{border-color:#c9d8ee;color:#31415c;background:#fff}.ghostButton:hover,.smallButton:hover{background:#eef5ff}.errorBox{background:#fff1f2;border-color:#ffc9cf;color:#c72f3a}@media (max-width: 760px){.loginScreen{padding-top:30px}.loginCard{padding:38px 24px 32px;border-radius:26px}.loginBrandIcon.ciFullLogo{width:210px;max-height:68px}.loginCard h1{font-size:44px}.loginDesc{font-size:15px}}
