:root{--primary-gradient: linear-gradient(135deg, #6366f1 0%, #a855f7 50%, #ec4899 100%);--secondary-gradient: linear-gradient(135deg, #3b82f6 0%, #2dd4bf 100%);--surface-gradient: linear-gradient(180deg, rgba(255, 255, 255, .7) 0%, rgba(255, 255, 255, .4) 100%);--line-1: #0052A4;--line-2: #009D3E;--line-3: #EF7C1C;--line-4: #00A5DE;--line-5: #996CAC;--line-6: #CD7C2F;--line-7: #747F00;--line-8: #E6186C;--line-9: #BDB092;--glass-bg: rgba(255, 255, 255, .7);--glass-border: rgba(255, 255, 255, .5);--glass-shadow: 0 8px 32px 0 rgba(31, 38, 135, .07);--glass-blur: blur(20px);--glass-saturation: 180%;--text-primary: #030213;--text-secondary: #4b5563;--text-tertiary: #9ca3af;--radius-xl: 24px;--radius-lg: 16px;--radius-md: 12px;--header-height: 60px;--composer-height: 70px;--composer-padding: 8px 16px;--composer-gap: 8px;--composer-bg: rgba(255, 255, 255, .9);--composer-form-height: 40px;--composer-form-padding: 4px 10px;--composer-form-gap: 6px;--composer-form-bg: #f1f3f5;--composer-form-bg-focus: white;--composer-form-radius: 20px;--composer-form-border-focus: #A855F7;--composer-input-padding: 0px 6px;--composer-input-min-height: 28px;--composer-input-max-height: 100px;--composer-input-font-size: 14px;--composer-input-line-height: 28px;--composer-btn-size: 32px;--composer-btn-icon-color: #9ca3af;--composer-btn-hover-bg: rgba(168, 85, 247, .1);--composer-btn-hover-color: #A855F7;--composer-send-bg: #dee2e6;--composer-send-bg-active: #A855F7;--emoji-picker-bg: white;--emoji-picker-radius: 16px;--emoji-picker-padding: 12px;--emoji-picker-gap: 8px;--emoji-item-size: 36px;--emoji-item-hover-bg: #F3E8FF}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}body{margin:0;font-family:Pretendard,sans-serif;background:#f8fafc;color:var(--text-primary);min-height:100vh;overflow-x:hidden}.animated-bg-container{position:fixed;top:0;right:0;bottom:0;left:0;z-index:-10;overflow:hidden;background:radial-gradient(circle at 12% 10%,#1b2334,transparent 40%),radial-gradient(circle at 82% 20%,#182033,transparent 35%),linear-gradient(180deg,#0c1016,#0f1724)}.orb{position:absolute;border-radius:50%;filter:blur(60px);opacity:.2;animation-iteration-count:infinite;animation-timing-function:ease-in-out}.orb-1{width:24rem;height:24rem;background:linear-gradient(135deg,#6366f1,#a855f7,#ec4899);top:10%;left:10%;animation-name:float-1;animation-duration:20s}.orb-2{width:20rem;height:20rem;background:linear-gradient(135deg,#ec4899,#a855f7);top:60%;right:5%;animation-name:float-2;animation-duration:15s}.orb-3{width:18rem;height:18rem;background:linear-gradient(135deg,#a855f7,#6366f1);bottom:5%;left:30%;animation-name:float-3;animation-duration:18s}@keyframes float-1{0%,to{transform:translate(0) scale(1)}50%{transform:translate(100px,50px) scale(1.1)}}@keyframes float-2{0%,to{transform:translate(0) scale(1)}50%{transform:translate(-80px,-60px) scale(1.2)}}@keyframes float-3{0%,to{transform:translate(0) scale(1)}50%{transform:translate(-50px,40px) scale(1.15)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse-glow{0%{box-shadow:0 0 #22c55e66}70%{box-shadow:0 0 0 6px #22c55e00}to{box-shadow:0 0 #22c55e00}}.loading{display:flex;flex-direction:column;justify-content:center;align-items:center;height:100vh;font-weight:600;color:var(--text-secondary);background:#f8fafc;gap:16px}.loading p{margin:0;font-size:15px;color:var(--text-secondary)}.route-loading{display:flex;align-items:center;justify-content:center;min-height:38vh;font-size:14px;font-weight:700;color:#f8fafce6}.route-skeleton{width:min(880px,calc(100% - 32px));margin:28px auto;display:grid;gap:14px}.route-skeleton-fullscreen{min-height:100vh;align-content:center}.route-skeleton-header,.route-skeleton-card,.route-skeleton-line,.route-skeleton-chip,.route-skeleton-bubble{border-radius:14px;border:1px solid rgba(148,163,184,.24);background:linear-gradient(90deg,#1e293b8f 25%,#47556973,#1e293b8f 75%);background-size:220% 100%;animation:route-skeleton-shimmer 1.4s ease-in-out infinite}.route-skeleton-header{height:48px}.route-skeleton-body{display:grid;gap:10px}.route-skeleton-card{height:96px}.route-skeleton-line{height:14px;border-radius:999px}.route-skeleton-line-long{width:100%}.route-skeleton-line-mid{width:72%}.route-skeleton-line-short{width:52%}.route-skeleton-chip{width:84px;height:30px;border-radius:999px}.route-skeleton-line-toolbar{display:flex;gap:10px;align-items:center}.route-skeleton-line-toolbar .route-skeleton-line-long{flex:1}.route-skeleton-line-topic{height:86px}.route-skeleton-chat-list{display:grid;gap:10px}.route-skeleton-bubble{height:58px;width:min(78%,460px)}.route-skeleton-bubble-left{justify-self:flex-start}.route-skeleton-bubble-right{justify-self:flex-end}.route-skeleton-bubble-short{width:min(62%,340px)}.route-skeleton-legal{display:grid;gap:12px}.route-skeleton-line .route-skeleton-header{width:58%}.route-skeleton-preview .route-skeleton-header{width:45%}.route-skeleton-preview-card{height:110px}.route-skeleton-legal .route-skeleton-header{width:42%}@keyframes route-skeleton-shimmer{0%{background-position:100% 0}to{background-position:-100% 0}}.route-transition-frame{animation:route-enter .22s cubic-bezier(.2,.8,.2,1);transform-origin:center top}@keyframes route-enter{0%{opacity:0;transform:translateY(8px) scale(.995)}to{opacity:1;transform:translateY(0) scale(1)}}button{transition:transform .16s ease,box-shadow .16s ease,filter .16s ease,background-color .16s ease}button:active:not(:disabled){transform:translateY(1px) scale(.985)}button:disabled{cursor:not-allowed}.spinner{width:40px;height:40px;border:3px solid rgba(168,85,247,.1);border-top-color:#a855f7;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.auth-check-loading{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;background:#fff}.dev-control-trigger{position:fixed;bottom:20px;right:20px;width:44px;height:44px;border-radius:50%;background:#333;color:#fff;border:none;font-size:20px;cursor:pointer;z-index:10000;box-shadow:0 4px 12px #0003;display:flex;align-items:center;justify-content:center;transition:transform .2s}.dev-control-trigger:hover{transform:scale(1.1)}.dev-control-panel{position:fixed;bottom:80px;right:20px;width:240px;background:#fff;border-radius:16px;box-shadow:0 10px 25px #0003;z-index:10000;overflow:hidden;border:1px solid #eee;animation:fadeInUp .2s ease-out}.dev-control-header{padding:12px 16px;background:#f8fafc;border-bottom:1px solid #eee;display:flex;justify-content:space-between;align-items:center;font-weight:700;font-size:13px;color:#333}.dev-control-header .close-btn{background:none;border:none;cursor:pointer;font-size:14px;padding:4px}.dev-control-content{padding:8px;display:flex;flex-direction:column}.mode-option{display:flex;align-items:center;gap:8px;padding:10px 12px;border-radius:8px;cursor:pointer;font-size:13px;color:#555;transition:background .2s}.mode-option:hover{background:#f1f5f9}.mode-option.active{background:#f0fdf4;color:#15803d;font-weight:600}.dev-control-footer{padding:8px 16px;background:#fafafa;border-top:1px solid #eee;color:#999;font-size:11px;text-align:center}body{background:radial-gradient(circle at 12% 10%,#1b2334,transparent 40%),radial-gradient(circle at 82% 20%,#182033,transparent 35%),linear-gradient(180deg,#0c1016,#0f1724);color:#f8fafc;font-family:IBM Plex Sans KR,Pretendard,-apple-system,BlinkMacSystemFont,system-ui,Segoe UI,Roboto,sans-serif;scrollbar-width:none;-ms-overflow-style:none}body::-webkit-scrollbar{width:0;height:0}.loading-fullscreen{display:flex;justify-content:center;align-items:center;min-height:100vh}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);clip-path:inset(50%);white-space:nowrap;border:0}:focus-visible{outline:2px solid #d5ff2e;outline-offset:2px}:focus:not(:focus-visible){outline:none}button:focus-visible,a:focus-visible,input:focus-visible,textarea:focus-visible,select:focus-visible,[tabindex]:focus-visible{outline:2px solid #d5ff2e;outline-offset:2px;border-radius:4px}.skip-to-content{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden;z-index:9999}.skip-to-content:focus{position:fixed;top:8px;left:50%;transform:translate(-50%);width:auto;height:auto;padding:12px 24px;background:var(--color-primary, #3b82f6);color:#fff;border-radius:8px;font-size:14px;font-weight:600;text-decoration:none;box-shadow:0 4px 12px #0000004d}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:1ms!important;animation-iteration-count:1!important;transition-duration:1ms!important;scroll-behavior:auto!important}.route-transition-frame{animation:none}}.toss-webview body{overscroll-behavior:none;-webkit-overflow-scrolling:touch}.toss-webview body{-webkit-user-select:none;user-select:none}.toss-webview input,.toss-webview textarea{-webkit-user-select:text;user-select:text}.toss-webview *{touch-action:manipulation}.toss-webview .home-container{padding-top:env(safe-area-inset-top,0px);padding-bottom:env(safe-area-inset-bottom,0px)}.toss-webview .animated-bg-container{display:none}.header{position:relative;margin:0;padding:16px 0 0}.header-content{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:0 20px}.header h1{margin:0}.header-logo-btn{background:none;border:none;padding:0;cursor:pointer;font:inherit;color:inherit;text-align:left;transition:opacity .2s}.header-logo-btn:hover{opacity:.8}.share-button{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:#ffffffb3;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.5);border-radius:12px;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);color:var(--text-secondary);padding:0}.share-button:hover{background:#ffffffe6;transform:translateY(-2px);color:var(--text-primary);box-shadow:0 4px 12px #0000001a}.share-button:active{transform:scale(.95)}.toast-message{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:#10b981f2;color:#fff;padding:12px 24px;border-radius:12px;font-size:14px;font-weight:600;box-shadow:0 8px 24px #00000026;z-index:10000;animation:toastFadeIn .15s ease,toastFadeOut .2s ease 1.7s forwards;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}@keyframes toastFadeIn{0%{opacity:0}to{opacity:1}}@keyframes toastFadeOut{to{opacity:0}}.footer{text-align:center;padding:24px 20px 40px;color:var(--text-tertiary);font-size:13px;font-weight:500;margin-top:auto}.main-content,.main-content .container{background:#111827}.header .container{background:transparent}.header{position:sticky;top:0;z-index:1000;padding:12px 0 0;background:#0f1521;border-bottom:none;backface-visibility:hidden;transform:translateZ(0);will-change:transform}.header-content{border:none;border-radius:0;background:transparent;box-shadow:none;padding:12px 16px}.header h1{font-family:Unbounded,sans-serif;font-size:20px;color:#f8fafc;white-space:pre-line}.share-button,.feedback-button-icon,.theme-toggle-btn,.auth-button{border:2px solid #000;box-shadow:4px 4px #000;background:#fff;color:#000}.share-button,.feedback-button-icon,.theme-toggle-btn{width:44px;height:44px;padding:0}.theme-toggle-btn{display:flex;align-items:center;justify-content:center;border-radius:12px;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1)}.theme-toggle-btn:hover{transform:translateY(-2px);box-shadow:6px 6px #000}.theme-toggle-btn:active{transform:scale(.95)}.toast-message{border:2px solid #000;box-shadow:6px 6px #000;background:#101826;color:#d6ff2f}.footer{background:#0f1521;border-top:none;color:#e2e8f0;box-shadow:none}.footer-links{display:flex;align-items:center;justify-content:center;gap:12px;margin-bottom:8px}.footer-link{color:#94a3b8;text-decoration:none;font-size:12px;font-weight:500;transition:color .2s}.footer-link:hover{color:#f8fafc}.footer-divider{color:#334155;font-size:12px}.footer-copyright{margin:0;font-size:12px;color:#94a3b8}.modal-footer-text{font-size:13px;color:var(--text-tertiary);margin:24px 0 0;font-weight:500}.auth-login-btn{background:var(--primary-gradient);color:#fff;border:none;padding:8px 16px;border-radius:12px;font-weight:600;cursor:pointer;font-size:14px;transition:opacity .2s}.auth-button-container{display:flex;align-items:center}.auth-user-menu{position:relative;display:inline-block}.auth-user-button{background:#ffffff80;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.8);padding:8px 16px;border-radius:100px;font-size:14px;font-weight:600;color:var(--text-primary);cursor:pointer;box-shadow:0 2px 8px #0000000d;transition:all .2s ease;display:flex;align-items:center;gap:6px}.auth-user-button:hover{background:#fffc;transform:translateY(-1px);box-shadow:0 4px 12px #00000014}.auth-user-button:active{transform:scale(.98)}.auth-dropdown{position:absolute;top:100%;right:0;margin-top:8px;background:#fffffff2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:16px;border:1px solid rgba(255,255,255,.5);box-shadow:0 10px 40px #0000001a;padding:8px;min-width:180px;z-index:1000;animation:slideUp .2s cubic-bezier(.2,.8,.2,1)}.auth-dropdown-item{display:block;width:100%;padding:10px 12px;text-align:left;border:none;background:transparent;border-radius:8px;font-size:14px;color:var(--text-primary);cursor:pointer;transition:background .2s}.auth-dropdown-item:hover{background:#0000000a}.auth-user-info{font-weight:600;border-bottom:1px solid rgba(0,0,0,.05);margin-bottom:4px;cursor:default}.auth-user-info:hover{background:transparent}.auth-logout-btn{color:#ef4444;font-weight:500}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .3s ease}.modal-overlay-purple{position:fixed;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,#a78bfa4d,#c084fc66,#d8b4fe4d);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .3s ease}.modal-content{background:#ffffffe6;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);width:90%;max-width:400px;border-radius:32px;padding:40px 32px;position:relative;box-shadow:0 20px 40px #0003;border:1px solid rgba(255,255,255,.5);text-align:center;animation:scaleIn .3s cubic-bezier(.175,.885,.32,1.275)}.modal-content-new{background:#fff;width:90%;max-width:380px;border-radius:28px;padding:48px 32px 32px;position:relative;box-shadow:0 24px 48px #00000026;text-align:center;animation:scaleIn .3s cubic-bezier(.175,.885,.32,1.275)}.modal-icon-wrapper{display:flex;justify-content:center;margin-bottom:24px}.lock-icon-container{position:relative;width:80px;height:80px;background:#f3f4f6;border-radius:20px;display:flex;align-items:center;justify-content:center}.lock-icon{position:relative;z-index:1}.check-badge{position:absolute;bottom:-4px;right:-4px;width:24px;height:24px;background:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #0000001a;z-index:2}.modal-title-new{font-size:26px;font-weight:800;margin:0 0 12px;color:var(--text-primary)}.modal-desc-new{font-size:15px;color:var(--text-secondary);line-height:1.6;margin:0 0 32px}.login-buttons-new{display:flex;flex-direction:column;gap:12px;margin-bottom:20px}.login-btn-anonymous{width:100%;padding:16px;border-radius:14px;font-size:16px;font-weight:600;display:flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;transition:all .2s;background:#fff;border:1.5px solid #E5E7EB;color:var(--text-primary)}.login-btn-anonymous:hover{background:#f9fafb;border-color:#d1d5db;transform:translateY(-2px)}.login-btn-anonymous:active{transform:translateY(0)}.btn-icon-anonymous{font-size:20px}.btn-text-anonymous{font-size:15px}.modal-later-link{background:transparent;border:none;color:var(--text-tertiary);font-size:14px;font-weight:500;cursor:pointer;padding:8px;transition:color .2s}.modal-later-link:hover{color:var(--text-secondary)}.modal-close{position:absolute;top:20px;right:20px;background:transparent;border:none;color:var(--text-tertiary);cursor:pointer;padding:8px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:background .2s}.modal-close:hover{background:#0000000d;color:var(--text-secondary)}.modal-title{font-size:24px;font-weight:800;margin:0 0 12px;background:var(--primary-gradient);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.modal-desc{font-size:15px;color:#a1a9b8;line-height:1.6;margin:0 0 32px}.login-buttons{display:flex;flex-direction:column;gap:12px;margin-bottom:24px}.login-btn{width:100%;padding:16px;border-radius:16px;font-size:16px;font-weight:600;display:flex;align-items:center;justify-content:center;gap:12px;cursor:pointer;transition:all .2s;border:none}.login-btn.anonymous{background:#fff9;border:1px solid rgba(0,0,0,.1);color:var(--text-primary)}.login-btn.anonymous:hover{background:#ffffffe6;transform:translateY(-2px)}.modal-footer{font-size:13px;color:var(--text-tertiary);margin:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scaleIn{0%{transform:scale(.9);opacity:0}to{transform:scale(1);opacity:1}}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:10000;display:flex;align-items:center;justify-content:center;padding:20px;animation:fadeIn .3s ease}.modal-content{background:#fff;width:100%;max-width:320px;border-radius:24px;padding:32px 24px;text-align:center;box-shadow:0 20px 50px #0003;transform:translateY(0);animation:slideUp .3s cubic-bezier(.16,1,.3,1)}.modal-icon{font-size:48px;margin-bottom:20px;animation:wave 2s infinite;display:inline-block}.modal-content h2{font-size:20px;font-weight:700;color:#1f2937;margin:0 0 12px}.modal-content p{font-size:15px;color:#4b5563;margin:0 0 24px;line-height:1.6}.modal-subtext{font-size:13px!important;color:#6b7280!important;background:#f3f4f6;padding:8px 12px;border-radius:8px;display:inline-block;margin-bottom:24px!important;font-weight:500}.modal-button{width:100%;padding:14px;border:none;border-radius:16px;background:linear-gradient(135deg,#6366f1,#a855f7);color:#fff;font-size:16px;font-weight:700;cursor:pointer;transition:transform .2s}.modal-button:active{transform:scale(.96)}@keyframes wave{0%,to{transform:rotate(0)}25%{transform:rotate(15deg)}75%{transform:rotate(-10deg)}}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}@media(min-width:900px){.app-shell{max-width:430px;margin:24px auto 48px;background:#0f1521;border:2px solid #000;box-shadow:12px 12px #000;border-radius:18px;overflow:hidden;min-height:calc(100vh - 72px);position:relative}.app-shell .chat-container{position:relative;inset:auto;height:100%;min-height:calc(100vh - 72px);background:#0f1521}.app-shell .chat-header{position:sticky;top:0;left:0;right:0;width:100%}.app-shell .chat-composer{position:absolute;bottom:0;left:0;right:0;width:100%}.app-shell .chat-messages{background:#0f1521}}.home-container{background:#111827;min-height:100vh;max-width:448px;margin:0 auto;border-left:1px solid rgba(30,41,59,.3);border-right:1px solid rgba(30,41,59,.3);font-family:Spline Sans,IBM Plex Sans KR,Pretendard,-apple-system,BlinkMacSystemFont,system-ui,sans-serif;color:#e2e8f0;display:flex;flex-direction:column;contain:layout style}.home-loading-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 12% 10%,rgba(27,35,52,.98),transparent 40%),radial-gradient(circle at 82% 20%,rgba(24,32,51,.95),transparent 35%),linear-gradient(180deg,#0c1016fa,#0f1724fa);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;z-index:2000;color:#e2e8f0}.home-loading-text{margin:0;font-size:14px;font-weight:600}.home-header{padding:24px 24px 16px}.home-header-content{display:flex;justify-content:space-between;align-items:flex-start}.home-brand{font-size:30px;font-weight:900;letter-spacing:-.05em;color:#d5ff2e;font-style:italic;text-transform:uppercase;margin:0;line-height:1.1}.home-brand-sub{font-size:12px;font-weight:500;color:#94a3b8;margin:4px 0 0;text-transform:uppercase;letter-spacing:.1em}.home-live-badge{background:#d5ff2e;border:2px solid #000;box-shadow:4px 4px #000;padding:4px 12px;border-radius:8px}.home-live-badge span{font-size:10px;font-weight:700;color:#000;text-transform:uppercase}.home-banner{padding:0 24px;margin-bottom:24px}.home-banner-content{background:#d5ff2e;border:2px solid #000;box-shadow:4px 4px #000;border-radius:12px;padding:16px;display:flex;align-items:center;gap:16px}.home-banner-icon{background:#000;color:#d5ff2e;border-radius:9999px;padding:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.home-banner-icon svg{width:24px;height:24px}.home-banner-title{font-size:14px;font-weight:700;color:#000;margin:0}.home-banner-desc{font-size:11px;font-weight:500;color:#000000b3;margin:2px 0 0;line-height:1.4}.home-sort-nav{padding:0 24px;margin-bottom:24px}.home-sort-tabs{display:flex;border:2px solid #000;border-radius:12px;overflow:hidden;background:#1e293b;box-shadow:4px 4px #000}.home-sort-tab{flex:1;padding:12px;font-size:14px;font-weight:700;color:#94a3b8;background:transparent;border:none;cursor:pointer;transition:color .2s,background .2s}.home-sort-tab:hover{color:#fff}.home-sort-tab.active{background:#d5ff2e;color:#000;border:2px solid #000;margin:-1px;z-index:10;border-radius:12px}.home-grid-container{padding:0 24px;flex:1}.home-line-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:40px;contain:content}.home-line-card{background:#1e293b80;border:2px solid #000;box-shadow:4px 4px #000;border-radius:12px;padding:12px;aspect-ratio:1;display:flex;flex-direction:column;align-items:center;justify-content:space-between;cursor:pointer;transition:all .15s ease;animation:fadeInUp .4s ease backwards}.home-line-card:active{transform:translate(1px,1px);box-shadow:none}.home-line-card:focus-visible{outline:2px solid #d5ff2e;outline-offset:2px}.home-line-card:nth-child(1){animation-delay:.03s}.home-line-card:nth-child(2){animation-delay:.06s}.home-line-card:nth-child(3){animation-delay:.09s}.home-line-card:nth-child(4){animation-delay:.12s}.home-line-card:nth-child(5){animation-delay:.15s}.home-line-card:nth-child(6){animation-delay:.18s}.home-line-card:nth-child(7){animation-delay:.21s}.home-line-card:nth-child(8){animation-delay:.24s}.home-line-card:nth-child(9){animation-delay:.27s}.home-line-circle{width:40px;height:40px;border-radius:9999px;border:2px solid #000;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:18px}.home-line-card-info{text-align:center}.home-line-card-name{display:block;font-size:11px;font-weight:700;color:#cbd5e1}.home-line-card-users{display:flex;align-items:center;justify-content:center;gap:4px;margin-top:4px}.home-pulse-dot{width:6px;height:6px;border-radius:9999px;background:#d5ff2e}.home-line-card-count{font-size:9px;font-weight:500;color:#94a3b8}.home-congestion-badge{padding:2px 8px;border-radius:9999px;font-size:9px;font-weight:700}.home-congestion-low{background:#10b98133;color:#34d399;border:1px solid rgba(16,185,129,.3)}.home-congestion-moderate{background:#eab30833;color:#facc15;border:1px solid rgba(234,179,8,.3)}.home-congestion-high{background:#ef444433;color:#f87171;border:1px solid rgba(239,68,68,.3)}.home-congestion-very_high{background:#dc26264d;color:#f87171;border:1px solid rgba(220,38,38,.4)}.home-footer{padding:8px 24px 24px;border-top:1px solid rgba(30,41,59,.5)}.home-footer-status{display:flex;align-items:center;gap:8px;margin-bottom:16px}.home-footer-status-dot{width:8px;height:8px;border-radius:9999px;background:#d5ff2e;box-shadow:0 0 8px #d5ff2e99}.home-footer-status-text{font-size:11px;font-weight:700;color:#94a3b8;text-transform:uppercase;letter-spacing:-.05em}.home-footer-about{font-size:11px;font-weight:700;color:#d5ff2e;text-decoration:underline;margin-left:auto}.home-footer-stats{display:grid;grid-template-columns:1fr 1fr;gap:12px}.home-footer-stat-card{background:#1e293b;border:2px solid #000;box-shadow:4px 4px #000;border-radius:12px;padding:12px;display:flex;align-items:center;gap:12px}.home-stat-icon{color:#d5ff2e;font-size:20px}.home-footer-stat-label{font-size:10px;color:#94a3b8;margin:0;line-height:1}.home-footer-stat-value{font-size:14px;font-weight:900;color:#fff;margin:2px 0 0}.home-rewarded-section{margin-top:16px}.home-footer-copyright{margin-top:32px;text-align:center}.home-footer-copyright p{font-size:10px;color:#475569;font-weight:500;margin:0}.preview-phone{width:min(430px,100%);background:#111827;border:3px solid #000;border-radius:28px;box-shadow:6px 6px #000;padding:16px;color:#f8fafc;font-family:IBM Plex Sans KR,sans-serif}.preview-home-container{display:grid;gap:14px}.preview-home-header{border:2px solid #000;border-radius:16px;background:#0f1521;padding:12px}.preview-home-subtitle{margin:0;color:#a1a9b8;font-size:12px;line-height:1.5}.preview-sort-tabs{display:flex;gap:10px}.preview-sort-tab{border:2px solid #000;border-radius:999px;padding:8px 12px;background:#fff;color:#000;font-weight:700;box-shadow:6px 6px #000}.preview-sort-tab.preview-active{background:#d6ff2f}.preview-subway-lines-list{display:grid;gap:12px}.preview-subway-line-item{border:2px solid #000;border-radius:16px;background:#fff;color:#000;padding:12px;display:flex;gap:12px;align-items:center;box-shadow:6px 6px #000}.preview-line-indicator{width:40px;height:40px;border-radius:12px;display:grid;place-items:center;color:#fff;font-weight:800;border:2px solid #000}.preview-line-1{background:#0052a4}.preview-line-2{background:#00a84d}.preview-line-3{background:#ef7c1c}.preview-line-4{background:#00a5de}.preview-line-5{background:#996cac}.preview-line-6{background:#cd7c2f}.preview-line-7{background:#747f00}.preview-line-8{background:#e6186c}.preview-line-9{background:#bdb092;color:#000}.preview-line-name{margin:0;font-family:Unbounded,sans-serif;font-size:14px}.preview-active-users-group{display:flex;align-items:center;gap:6px;font-size:12px;color:#111}.preview-pulse-dot{width:8px;height:8px;border-radius:50%;background:#ff3db8;box-shadow:0 0 0 4px #ff3db833}.preview-inactive-users{color:#6b7280}.preview-chat-header{border:2px solid #000;border-radius:16px;background:#0f1521;padding:10px;display:flex;align-items:center;gap:10px}.preview-chat-back-btn{width:36px;height:36px;border-radius:10px;border:2px solid #000;background:#fff;color:#000;display:grid;place-items:center;font-weight:800}.preview-chat-line-badge{width:36px;height:36px;border-radius:12px;background:#00a84d;color:#fff;display:grid;place-items:center;border:2px solid #000;font-family:Unbounded,sans-serif}.preview-chat-title{margin:0;font-family:Unbounded,sans-serif;font-size:14px}.preview-chat-meta{display:flex;align-items:center;gap:6px;font-size:12px;color:#d6ff2f}.preview-pulse-dot-small{width:8px;height:8px;border-radius:50%;background:#ff3db8;box-shadow:0 0 0 4px #ff3db833}.preview-chat-messages{margin-top:12px;display:grid;gap:12px}.preview-welcome-notice,.preview-message-content{border:2px solid #000;border-radius:14px;padding:10px 12px;box-shadow:6px 6px #000;background:#fff;color:#000}.preview-date-divider{text-align:center;font-size:12px;color:#a1a9b8}.preview-message-wrapper{display:flex}.preview-message-wrapper.preview-my-message{justify-content:flex-end}.preview-message-wrapper.preview-my-message .preview-message-content{background:#d6ff2f}.preview-message-nickname{font-size:11px;font-weight:700}.preview-message-meta{font-size:11px;color:#333}.preview-chat-composer{margin-top:14px;border-top:3px solid #000;padding-top:12px;display:grid;gap:10px}.preview-reply-bar{border:2px solid #000;border-radius:12px;padding:8px 10px;background:#fff;color:#000;display:flex;justify-content:space-between;font-size:12px}.preview-composer-form{display:flex;gap:10px;align-items:center}.preview-composer-input{flex:1;border:2px solid #000;border-radius:14px;background:#0f1521;color:#f8fafc;padding:12px;font-size:14px}.preview-composer-send{width:48px;height:48px;border:2px solid #000;border-radius:14px;background:#ff3db8;color:#000;font-weight:800;box-shadow:6px 6px #000}.trivia-card{background:linear-gradient(135deg,#6366f114,#a855f714);border:1px solid rgba(99,102,241,.2);border-radius:16px;padding:16px;margin:0 0 20px;transition:all .3s ease}.trivia-header{margin-bottom:12px}.trivia-badge{font-size:12px;font-weight:700;color:#6366f1;background:#6366f126;padding:4px 10px;border-radius:12px;display:inline-block}.trivia-content{text-align:left}.trivia-title{font-size:15px;font-weight:700;color:var(--text-primary);margin:0 0 8px;line-height:1.4}.trivia-text{font-size:13px;color:var(--text-secondary);margin:0;line-height:1.6}.toss-webview .home-header{padding-top:calc(env(safe-area-inset-top,0px) + 24px)}.toss-webview .home-footer{padding-bottom:calc(env(safe-area-inset-bottom,0px) + 24px)}.toss-webview .home-sort-tab{min-height:44px;padding:14px 12px}.toss-webview .home-line-card{min-height:100px}.toss-webview .home-footer-about{padding:8px 12px;margin:-8px -12px}.toss-webview .home-retry-btn{min-height:44px;min-width:120px}.ait-banner-slot{margin:0 24px 16px;border:2px solid #000;border-radius:12px;box-shadow:4px 4px #000;overflow:hidden;background:#1e293b80}.ait-banner-slot:empty{display:none}.ait-rewarded-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:14px;background:#d5ff2e;color:#000;font-size:14px;font-weight:700;border:2px solid #000;border-radius:12px;box-shadow:4px 4px #000;cursor:pointer;transition:transform .1s,box-shadow .1s,opacity .2s}.ait-rewarded-btn:active:not(:disabled){transform:translate(2px,2px);box-shadow:2px 2px #000}.ait-rewarded-btn:disabled{opacity:.5;cursor:not-allowed}.ait-rewarded-icon{width:20px;height:20px;flex-shrink:0}.ait-rewarded-label{letter-spacing:-.02em}.error-boundary{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;padding:2rem;text-align:center}.error-boundary__title{font-size:1.5rem;margin-bottom:.5rem}.error-boundary__message{color:#666;margin-bottom:1.5rem;max-width:400px}.error-boundary__retry-btn{padding:.75rem 1.5rem;border-radius:8px;border:none;background-color:#0052a4;color:#fff;font-size:1rem;cursor:pointer}.error-boundary__retry-btn:hover{opacity:.9}.error-boundary__stack{margin-top:1.5rem;padding:1rem;background-color:#f5f5f5;border-radius:8px;font-size:.75rem;text-align:left;max-width:100%;overflow:auto;color:#c00}.header-buttons{display:flex;align-items:center;gap:8px}.feedback-button-icon{background:#ffffff14;border:2px solid #000;border-radius:12px;padding:0;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;box-shadow:2px 2px #000}.feedback-button-icon:hover{transform:translateY(-2px);box-shadow:4px 4px #000}.feedback-button-icon:active{transform:translateY(0);box-shadow:2px 2px #000}.feedback-button-icon svg{color:#d5ff2e;transition:color .2s ease}.feedback-button-icon:hover svg{color:#e8ff6b}.feedback-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);display:flex;align-items:flex-end;justify-content:center;z-index:10000}.feedback-sheet{background:#111827;border-top:2px solid #000;border-left:2px solid #000;border-right:2px solid #000;border-top-left-radius:12px;border-top-right-radius:12px;box-shadow:0 -8px 30px #00000080;width:100%;max-width:448px;max-height:90vh;overflow-y:auto;animation:feedback-slide-up .3s ease-out}@keyframes feedback-slide-up{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}.feedback-drag-handle-area{display:flex;justify-content:center;padding:12px 0 4px;cursor:grab}.feedback-drag-handle{width:48px;height:6px;background:#d5ff2e4d;border-radius:9999px}.feedback-content{padding:16px 24px 24px}.feedback-header{margin-bottom:24px}.feedback-title{font-family:Spline Sans,sans-serif;font-size:24px;font-weight:700;text-transform:uppercase;letter-spacing:-.02em;color:#d5ff2e;margin:0 0 4px}.feedback-desc{font-size:14px;color:#94a3b8;margin:0}.feedback-section-label{font-family:Spline Sans,sans-serif;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:#64748b;margin:0 0 8px}.feedback-categories{margin-bottom:20px}.feedback-chips{display:flex;flex-wrap:wrap;gap:8px}.feedback-chip{padding:8px 16px;border:2px solid #000;border-radius:9999px;background:#1e293b80;color:#cbd5e1;font-size:14px;font-weight:500;cursor:pointer;transition:all .15s ease;box-shadow:none}.feedback-chip:hover{background:#1e293bcc;color:#f8fafc}.feedback-chip.active{background:#d5ff2e;color:#000;box-shadow:2px 2px #00000080;font-weight:600}.feedback-textarea-section{margin-bottom:20px}.feedback-textarea{width:100%;min-height:120px;padding:16px;border:2px solid #000;border-radius:12px;background:#ffffff0d;color:#f8fafc;font-size:14px;font-family:IBM Plex Sans KR,Pretendard,-apple-system,sans-serif;line-height:1.6;resize:vertical;transition:border-color .2s ease,background-color .2s ease;box-sizing:border-box}.feedback-textarea:focus{outline:none;border-color:#d5ff2e;background:#ffffff14}.feedback-textarea::placeholder{color:#64748b}.feedback-textarea:disabled{opacity:.5;cursor:not-allowed}.feedback-error{color:#f87171;font-size:13px;margin-top:8px;padding:8px 12px;background:#ef444426;border-radius:8px;border-left:3px solid #f87171}.feedback-submit-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:8px;padding:16px;border:2px solid #000;border-radius:12px;background:#ff3db8;color:#fff;font-size:16px;font-weight:700;font-family:IBM Plex Sans KR,Pretendard,-apple-system,sans-serif;cursor:pointer;transition:all .15s ease;box-shadow:4px 4px #000}.feedback-submit-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:6px 6px #000}.feedback-submit-btn:active:not(:disabled){transform:translateY(0);box-shadow:2px 2px #000}.feedback-submit-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.feedback-submit-arrow{transition:transform .2s ease}.feedback-submit-btn:hover:not(:disabled) .feedback-submit-arrow{transform:translate(4px)}.feedback-safe-area{height:env(safe-area-inset-bottom,0px)}@media(max-width:768px){.feedback-sheet{max-width:100%;border-left:none;border-right:none;border-radius:12px 12px 0 0}.feedback-content{padding:12px 16px 20px}.feedback-title{font-size:20px}.feedback-textarea{min-height:100px}}
