:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}:root{--bg-color: #020617;--card-bg: #0f172a;--accent-color: #10b981;--accent-blue: #3b82f6;--text-main: #f8fafc;--text-muted: #94a3b8;--glass-border: rgba(255, 255, 255, .08)}body{margin:0;padding:0;background:radial-gradient(circle at top,#1e293b,#020617);color:var(--text-main);display:flex;justify-content:center;align-items:center;min-height:100vh;font-family:Pretendard,-apple-system,BlinkMacSystemFont,system-ui,Roboto,sans-serif;-webkit-tap-highlight-color:transparent}button,input{outline:none!important;-webkit-tap-highlight-color:transparent}.container{width:100vw;height:100vh;display:flex;justify-content:center}.mobile-card{width:100%;height:100%;background-color:var(--card-bg);padding:2rem;box-sizing:border-box;display:flex;flex-direction:column;overflow-y:auto;scrollbar-width:none;border:1px solid var(--glass-border)}.mobile-card::-webkit-scrollbar{display:none}@media(min-width:481px){.mobile-card{max-width:480px;height:90vh;margin-top:5vh;border-radius:24px;box-shadow:0 25px 50px -12px #00000080;border:1px solid rgba(255,255,255,.1)}}.welcome-container{display:flex;flex-direction:column;gap:4rem}.welcome-section{min-height:80vh;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center}.vibe-logo{font-size:5rem;margin-bottom:2rem;filter:drop-shadow(0 0 20px var(--accent-color))}.title{font-size:2.8rem;font-weight:800;margin-bottom:1rem;background:linear-gradient(to bottom right,#fff 30%,#94a3b8);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;letter-spacing:-.05em}.description{font-size:1.1rem;color:var(--text-muted);line-height:1.6;margin-bottom:2rem}.social-proof{font-size:.9rem;color:var(--text-muted);background:#38bdf81a;padding:.8rem 1.2rem;border-radius:12px;margin-bottom:1.5rem;line-height:1.5}.social-proof span{color:var(--accent-color);font-weight:700}.login-btn{width:100%;padding:1.2rem;border-radius:20px;border:none;background:linear-gradient(135deg,var(--accent-color) 0%,#059669 100%);color:#fff;font-weight:800;font-size:1.2rem;cursor:pointer;transition:all .4s cubic-bezier(.175,.885,.32,1.275);box-shadow:0 10px 25px -5px #10b98166}.login-btn:hover{transform:translateY(-4px) scale(1.02);box-shadow:0 20px 30px -10px #10b98199}.scroll-hint{margin-top:3rem;color:var(--text-muted);font-size:.8rem;display:flex;flex-direction:column;align-items:center;opacity:.6;animation:bounce 2s infinite}@keyframes bounce{0%,20%,50%,80%,to{transform:translateY(0)}40%{transform:translateY(-10px)}60%{transform:translateY(-5px)}}.preview-section{padding-bottom:4rem;animation:fadeIn 1s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.preview-title{text-align:center;margin-bottom:2rem;color:var(--text-main);font-size:1.3rem}.virtual-dashboard{background:#0f172a99;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:24px;padding:1.5rem;border:1px solid var(--glass-border);box-shadow:0 20px 40px #0006}.preview-card.summary{background:linear-gradient(135deg,var(--accent-blue) 0%,#1e40af 100%);padding:1.5rem;border-radius:20px;display:flex;flex-direction:column;margin-bottom:1.5rem;color:#fff;box-shadow:0 10px 20px #3b82f64d}.preview-card .label{font-size:.9rem;opacity:.9}.preview-card .value{font-size:1.8rem;font-weight:800}.preview-list{display:flex;flex-direction:column;gap:1rem}.preview-item{display:flex;align-items:center;gap:1rem;background:#ffffff0d;padding:1rem;border-radius:12px}.item-icon{font-size:1.5rem}.item-info{flex:1}.item-name{font-weight:600;font-size:.95rem}.item-date{font-size:.8rem;color:var(--text-muted)}.item-price{font-weight:700;color:var(--accent-color)}.preview-footer{text-align:center;margin-top:2rem;color:var(--text-muted);font-size:.9rem}.user-header{display:flex;align-items:center;gap:1rem;padding-bottom:1.5rem;border-bottom:1px solid var(--glass-border)}.profile-img{width:44px;height:44px;border-radius:50%;border:2px solid var(--accent-color)}.user-info{flex:1}.user-name{font-weight:600;margin:0;font-size:.95rem}.logout-link{background:none;border:none;color:var(--text-muted);font-size:.75rem;padding:0;cursor:pointer;text-decoration:underline}.dashboard-content{flex:1;padding-top:1.5rem;display:flex;flex-direction:column;gap:2rem}.total-summary-card{background:linear-gradient(135deg,var(--accent-blue) 0%,#1e40af 100%);padding:2rem;border-radius:24px;text-align:center;box-shadow:0 20px 30px -10px #3b82f666}.summary-label{font-size:.9rem;opacity:.8;display:block;margin-bottom:.5rem}.total-price{font-size:2.5rem;font-weight:800;margin:0}.upcoming-badge{display:inline-block;margin-top:1rem;background:#ffffff26;padding:.5rem 1rem;border-radius:12px;font-size:.85rem;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);border:1px solid rgba(255,255,255,.1)}.upcoming-badge strong{color:#fbbf24}.sub-list-container h3{font-size:1.1rem;margin-bottom:1rem}.sub-list{display:flex;flex-direction:column;gap:.8rem;padding-bottom:80px}.sub-item{display:flex;align-items:center;gap:1rem;padding:1rem;background:#ffffff08;border-radius:16px;border:1px solid var(--glass-border);transition:all .2s cubic-bezier(.4,0,.2,1);cursor:pointer}.sub-item:hover{transform:translateY(-2px);background:#ffffff0d;border-color:#fff3}.sub-item.urgent-item{border:1px solid rgba(248,113,113,.3);background:#f871710d;box-shadow:0 0 15px #f871711a}.sub-item.urgent-item:hover{border-color:#f8717180}.sub-icon{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:#ffffff0d;border-radius:12px;overflow:hidden}.service-icon-img{width:24px;height:24px;object-fit:contain}.sub-info{flex:1}.sub-name{font-weight:600;font-size:1rem}.sub-date{font-size:.8rem;color:var(--text-muted)}.sub-meta{text-align:right;display:flex;flex-direction:column;gap:.2rem}.sub-dday{font-size:.75rem;color:var(--text-muted);font-weight:600}.sub-dday.urgent{color:#f87171;font-weight:700}.sub-price{font-weight:700;color:var(--accent-color);font-size:1rem}.empty-state{text-align:center;color:var(--text-muted);margin-top:3rem;line-height:1.6}.add-fab-btn{position:fixed;bottom:calc(2rem + env(safe-area-inset-bottom));right:2rem;width:60px;height:60px;border-radius:30px;background:linear-gradient(135deg,var(--accent-color) 0%,#059669 100%);color:#fff;font-size:2.2rem;border:none;cursor:pointer;box-shadow:0 15px 25px -5px #10b98180;display:flex;align-items:center;justify-content:center;transition:all .3s;z-index:1000}.add-fab-btn:hover{transform:rotate(90deg) scale(1.1)}.modal-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#000000d9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:9999;padding:1.5rem;box-sizing:border-box}.modal-content{background:var(--card-bg);width:100%;max-width:400px;padding:2rem;border-radius:24px;border:1px solid var(--glass-border);animation:modalUp .3s ease-out}@keyframes modalUp{0%{transform:translateY(50px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-content h3{margin-top:0;margin-bottom:1.5rem;font-size:1.4rem}.input-group{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1.2rem}.input-group label{font-size:.85rem;color:var(--text-muted)}.input-group input{background:#ffffff0d;border:1px solid var(--glass-border);padding:.8rem 1rem;border-radius:12px;color:#fff;font-size:1rem;outline:none;transition:border-color .2s}.input-group input:focus{border-color:var(--accent-color)}.input-group input.readonly-input{background:#ffffff05;color:var(--text-muted);border-color:transparent;cursor:default;font-weight:500;padding-left:0;font-size:1.1rem}.input-group input.readonly-input:focus{border-color:transparent;box-shadow:none}.ai-placeholder{font-size:.8rem;color:var(--accent-color);background:#10b9810d;padding:1rem;border-radius:16px;margin-bottom:1.2rem;border:1px dashed var(--accent-color)}.ai-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.8rem}.ai-status{margin-bottom:0;font-weight:600}.ai-refresh-btn{background:none;border:none;font-size:1rem;cursor:pointer;padding:4px;border-radius:50%;transition:transform .3s;line-height:1}.ai-refresh-btn:hover{transform:rotate(180deg);background:#ffffff1a}.ai-plan-list{display:flex;flex-wrap:wrap;gap:.5rem}.ai-plan-tag{background:#10b98126;border:1px solid var(--accent-color);color:var(--text-main);padding:.4rem .8rem;border-radius:10px;font-size:.75rem;cursor:pointer;transition:all .2s}.ai-help-text{font-size:.7rem;color:#fff6;margin-top:.8rem;line-height:1.4;word-break:keep-all}.input-group input:focus{outline:none;border-color:var(--accent-color);background:#10b9810d;box-shadow:0 0 0 4px #10b9811a}.modal-actions{display:grid;grid-template-columns:1fr 2fr;gap:1rem;margin-top:2rem}.cancel-btn,.submit-btn{padding:1rem;border-radius:14px;border:none;font-weight:700;cursor:pointer}.cancel-btn{background:#ffffff0d;color:var(--text-muted)}.submit-btn{background:linear-gradient(135deg,var(--accent-color) 0%,#059669 100%);color:#fff}.delete-btn{background:#f871711a;color:#f87171;border:1px solid rgba(248,113,113,.2);padding:1rem;border-radius:14px;font-weight:700;cursor:pointer;transition:all .2s}.delete-btn:hover{background:#f8717133}.modal-actions.edit{grid-template-columns:1fr 1fr 1.5fr}.loading{display:flex;justify-content:center;align-items:center;height:100vh;color:var(--accent-color);font-weight:700}.pwa-install-banner{position:fixed;bottom:1.5rem;left:1.5rem;right:1.5rem;background:var(--card-bg);border:1px solid var(--glass-border);border-radius:20px;padding:1.2rem;display:flex;flex-direction:column;gap:1rem;box-shadow:0 20px 40px #0009;z-index:10000;animation:slideUp .4s cubic-bezier(.175,.885,.32,1.275)}.pwa-info{display:flex;align-items:center;gap:1rem}.pwa-logo{font-size:2rem}.pwa-title{font-weight:700;font-size:1rem;margin:0}.pwa-desc{font-size:.8rem;color:var(--text-muted);margin:.2rem 0 0}.pwa-actions{display:grid;grid-template-columns:1fr 1fr;gap:.8rem}.pwa-close,.pwa-install{padding:.8rem;border-radius:12px;border:none;font-weight:700;font-size:.9rem;cursor:pointer}.pwa-close{background:#ffffff0d;color:var(--text-muted)}.pwa-install{background:linear-gradient(135deg,var(--accent-color) 0%,#059669 100%);color:#fff}.ios-pwa-guide{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#000c;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:10000;padding:2rem;box-sizing:border-box}.ios-guide-content{background:var(--card-bg);padding:2.5rem 2rem;border-radius:30px;text-align:center;border:1px solid var(--glass-border);max-width:320px}.ios-guide-header{margin-bottom:1.5rem}.ios-guide-header h3{margin:.5rem 0 0;font-size:1.3rem}.ios-guide-content p{color:var(--text-muted);line-height:1.6;margin-bottom:2rem;font-size:.95rem}.ios-icon{display:inline-block;background:#f1f5f9;color:#0f172a;padding:2px 6px;border-radius:6px;font-weight:700}.ios-guide-close{width:100%;padding:1rem;background:var(--accent-blue);color:#fff;border-radius:16px;border:none;font-weight:700;cursor:pointer}@keyframes slideUp{0%{transform:translateY(100px);opacity:0}to{transform:translateY(0);opacity:1}}
