.prototype-wrap{--proto-bg: #dde8e1;--proto-card: #fffcf9;--proto-text-secondary: #6a7268;--proto-border: #e5eae6;--phone-w: 375px;--phone-h: 812px;--status-h: 44px;--sidebar-w: 232px;min-height:100vh;display:flex;flex-direction:row;align-items:flex-start;justify-content:center;gap:28px;padding:20px 24px;background:var(--proto-bg);color:var(--text, #3a4038)}.proto-sidebar{width:var(--sidebar-w);flex-shrink:0;position:sticky;top:20px;max-height:calc(100vh - 40px);display:flex;flex-direction:column;background:var(--proto-card);border:1px solid var(--proto-border);border-radius:16px;box-shadow:0 4px 24px #5c877014;overflow:hidden}.proto-sidebar-head{padding:16px 14px 12px;border-bottom:1px solid var(--proto-border);background:linear-gradient(180deg,var(--primary-light, #e8f2ec) 0%,var(--proto-card) 100%)}.proto-sidebar-brand{font-size:15px;font-weight:700;color:var(--primary-dark, #5c8770);margin:0 0 4px;line-height:1.3}.proto-sidebar-meta{font-size:11px;color:var(--proto-text-secondary);margin:0}.proto-sidebar-nav{flex:1;overflow-y:auto;padding:10px 0 14px;-webkit-overflow-scrolling:touch}.proto-sidebar-nav::-webkit-scrollbar{width:4px}.proto-sidebar-nav::-webkit-scrollbar-thumb{background:var(--proto-border);border-radius:4px}.proto-nav-module{margin-bottom:4px}.proto-nav-module-title{font-size:11px;font-weight:700;color:var(--primary-dark, #5c8770);text-transform:none;letter-spacing:.02em;padding:10px 14px 6px;margin:0}.proto-nav-list{list-style:none;margin:0;padding:0 8px}.proto-nav-item{display:block;width:100%;text-align:left;font-size:12px;padding:7px 10px;margin-bottom:2px;border:none;border-radius:8px;background:transparent;cursor:pointer;font-family:inherit;color:var(--text-secondary, #6a7268);transition:background .15s,color .15s;line-height:1.35}.proto-nav-item:hover{background:var(--bg-soft, #eef3ef);color:var(--text, #3a4038)}.proto-nav-item.active{background:var(--primary-light, #e8f2ec);color:var(--primary-dark, #5c8770);font-weight:600}.prototype-main{display:flex;flex-direction:column;align-items:center;flex-shrink:0}.proto-header{text-align:center;margin-bottom:16px;max-width:420px}.proto-header h1{font-size:16px;margin-bottom:4px;font-weight:600;color:var(--primary-dark, #5c8770)}.proto-header p{font-size:12px;color:var(--proto-text-secondary);line-height:1.5;margin:0}.phone{width:var(--phone-w);height:var(--phone-h);background:var(--bg, #f7f5f0);border-radius:40px;border:8px solid #2a332e;overflow:hidden;position:relative;box-shadow:0 24px 64px #5c87702e;flex-shrink:0;display:flex;flex-direction:column}.status-bar{height:var(--status-h);background:#fffcf9f2;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:600;position:relative;flex-shrink:0;border-bottom:1px solid var(--proto-border);color:var(--text, #3a4038)}.status-bar .time{position:absolute;left:24px;font-size:13px;font-weight:600}.status-bar .status-title{max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.status-bar .icons{position:absolute;right:20px;font-size:11px;color:var(--text-secondary, #6a7268)}.phone-screen{flex:1;min-height:0;overflow:hidden;position:relative;background:var(--bg, #f7f5f0)}.phone-screen .app-shell{position:relative;max-width:100%;width:100%;height:100%;min-height:0;margin:0;box-shadow:none;overflow:hidden}.phone-screen .page,.phone-screen .page-no-tab{min-height:100%;height:100%;overflow-y:auto;-webkit-overflow-scrolling:touch}.phone-screen .page-no-tab[style*="100vh"],.phone-screen .video-chat-page{height:100%!important;min-height:100%!important}.phone-screen .splash--login{min-height:100%;height:100%}.phone-screen .tab-bar,.phone-screen .header,.phone-screen .bottom-actions{position:absolute;left:0;right:0;transform:none;max-width:100%;width:100%}.phone-screen .tab-bar{bottom:0}.phone-screen .header{top:0}.phone-screen .bottom-actions{bottom:0}.phone-screen .toast{position:absolute;top:72px;left:50%;transform:translate(-50%)}body:has(.prototype-wrap){background:var(--proto-bg, #dde8e1)}html:has(.prototype-wrap),body:has(.prototype-wrap),body:has(.prototype-wrap) #root{height:auto;min-height:100%}.prototype-main--map{width:min(1200px,calc(100vw - var(--sidebar-w) - 72px));align-items:stretch}.embed-root{width:375px;height:812px;overflow:hidden;background:var(--bg, #f7f5f0)}.embed-root .app-shell{width:100%;height:100%;min-height:0;overflow:hidden}.embed-root .page,.embed-root .page-no-tab{min-height:100%;height:100%;overflow-y:auto;-webkit-overflow-scrolling:touch}.embed-root .tab-bar,.embed-root .header,.embed-root .bottom-actions{position:absolute;left:0;right:0;max-width:100%}.embed-root .tab-bar,.embed-root .bottom-actions{bottom:0}.embed-root .header{top:0}.proto-map{width:100%;display:flex;flex-direction:column;gap:16px}.proto-map-toolbar{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;padding:4px 0 8px}.proto-map-title{font-size:18px;font-weight:700;color:var(--primary-dark, #5c8770);margin:0 0 4px}.proto-map-meta{font-size:12px;color:var(--proto-text-secondary);margin:0}.proto-map-zoom{display:flex;align-items:center;gap:8px;flex-shrink:0}.proto-map-zoom-btn{width:32px;height:32px;border-radius:8px;border:1px solid var(--proto-border);background:var(--proto-card);cursor:pointer;font-size:16px;line-height:1;color:var(--text-secondary)}.proto-map-zoom-label{font-size:12px;min-width:44px;text-align:center;color:var(--text-secondary)}.proto-map-canvas{flex:1;overflow:auto;max-height:calc(100vh - 100px);padding:8px 4px 32px;-webkit-overflow-scrolling:touch}.proto-map-module{margin-bottom:36px}.proto-map-module-title{font-size:13px;font-weight:700;color:var(--primary-dark, #5c8770);margin:0 0 14px;padding-bottom:8px;border-bottom:1px dashed var(--proto-border)}.proto-map-row{display:flex;flex-wrap:wrap;gap:20px 24px}.proto-map-frame{display:flex;flex-direction:column;align-items:center;padding:0;border:none;background:none;cursor:pointer;font-family:inherit;transition:transform .15s ease}.proto-map-frame:hover{transform:translateY(-2px)}.proto-map-frame:hover .proto-map-phone{box-shadow:0 12px 32px #5c877038;border-color:var(--primary, #7aa88e)}.proto-map-phone{border-radius:18px;border:4px solid #2a332e;overflow:hidden;background:var(--bg, #f7f5f0);box-shadow:0 8px 24px #0000001a;transition:box-shadow .15s,border-color .15s;position:relative}.proto-map-screen{transform-origin:top left;pointer-events:none}.proto-map-screen iframe{display:block;width:375px;height:812px;border:none;background:var(--bg, #f7f5f0)}.proto-map-label{margin-top:10px;font-size:12px;font-weight:600;color:var(--text, #3a4038);text-align:center;line-height:1.3}.proto-map-path{margin-top:2px;font-size:10px;color:var(--proto-text-secondary);font-family:ui-monospace,monospace}@media (max-width: 720px){.prototype-main--map{width:100%}.proto-map-toolbar{flex-direction:column}}@media (max-width: 720px){.prototype-wrap{flex-direction:column;align-items:stretch;padding:12px}.proto-sidebar{position:relative;top:0;width:100%;max-height:280px}.prototype-main{width:100%;align-items:center}}:root{--bg: #f7f5f0;--bg-card: #fffcf9;--bg-soft: #eef3ef;--bg-outer: #dde8e1;--primary: #7ba88a;--primary-light: #e8f2ec;--primary-dark: #5c8770;--primary-mid: #94b9a2;--primary-glow: rgba(123, 168, 138, .28);--accent-warm: #e8cfc0;--accent-lavender: #c9bdd8;--accent-peach: #f2e4dc;--accent-rose: #d4a8b4;--text: #3a4038;--text-secondary: #6a7268;--text-muted: #9aa398;--border: #e5eae6;--tab-inactive: #a8b0a6;--tab-active: #5c8770;--success: #6db892;--success-light: #e5f4ec;--warning: #d4bc7a;--warning-light: #f5efdc;--danger: #d89696;--danger-light: #f8ebeb;--shadow: 0 2px 20px rgba(92, 135, 112, .07);--shadow-soft: 0 6px 28px rgba(92, 135, 112, .1);--radius: 18px;--radius-sm: 12px;--font: "Noto Sans SC", -apple-system, sans-serif;--safe-bottom: env(safe-area-inset-bottom, 0px);--hall-pet-from: #faf4eb;--hall-pet-to: #f0e6d8;--hall-pet-border: #e8d9c8;--hall-pet-accent: #a89278;--hall-pet-badge: #f5ebe0;--hall-memorial-from: #f5f2f8;--hall-memorial-to: #ebe6f2;--hall-memorial-border: #ddd6e8;--hall-memorial-accent: #8a7da8;--hall-memorial-badge: #edeaf4;--hall-love-from: #faf2f4;--hall-love-to: #f2e4ea;--hall-love-border: #e8d4dc;--hall-love-accent: #b0788e;--hall-love-badge: #f5e8ed;--hall-future-from: #eff5f7;--hall-future-to: #e0ecf2;--hall-future-border: #c8dde8;--hall-future-accent: #6890a8;--hall-future-badge: #e4eef4;--stage-from: #3a4248;--stage-to: #2a3036;--stage-scan: rgba(123, 168, 138, .35);--stage-glow: rgba(123, 168, 138, .18)}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{font-family:var(--font);background:var(--bg-outer);color:var(--text);-webkit-font-smoothing:antialiased}.app-shell{max-width:430px;margin:0 auto;min-height:100%;background:var(--bg);position:relative;box-shadow:var(--shadow-soft)}.page{min-height:100vh;padding-bottom:calc(72px + var(--safe-bottom));background:linear-gradient(180deg,var(--bg) 0%,color-mix(in srgb,var(--bg-soft) 40%,var(--bg)) 100%)}.page-no-tab{min-height:100vh;padding-bottom:var(--safe-bottom);background:linear-gradient(180deg,var(--bg) 0%,color-mix(in srgb,var(--bg-soft) 40%,var(--bg)) 100%)}h1{font-size:1.5rem;font-weight:700;line-height:1.3}h2{font-size:1.25rem;font-weight:600}h3{font-size:1.05rem;font-weight:600}p{line-height:1.6}.text-secondary{color:var(--text-secondary)}.text-muted{color:var(--text-muted);font-size:.875rem}.text-sm{font-size:.875rem}.text-xs{font-size:.75rem}.px{padding-left:20px;padding-right:20px}.py{padding-top:16px;padding-bottom:16px}.pt-header{padding-top:56px}.gap-sm{gap:8px}.gap-md{gap:16px}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.flex-1{flex:1}.header{position:fixed;top:0;left:50%;transform:translate(-50%);width:100%;max-width:430px;height:56px;background:#f7f5f0e0;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 16px;z-index:100}.header-back{width:36px;height:36px;border:none;background:none;font-size:1.25rem;cursor:pointer;color:var(--text);border-radius:50%;display:flex;align-items:center;justify-content:center}.header-back:active{background:var(--border)}.header-title{flex:1;text-align:center;font-weight:600;font-size:1rem}.header-action{width:36px}.card{background:var(--bg-card);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow);border:1px solid var(--border)}.card-clickable{cursor:pointer;transition:transform .15s,box-shadow .15s}.card-clickable:active{transform:scale(.98)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:14px 24px;border-radius:50px;font-size:1rem;font-weight:600;font-family:var(--font);border:none;cursor:pointer;transition:all .15s;width:100%}.btn-primary{background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%);color:#fff;box-shadow:0 4px 14px var(--primary-glow)}.btn-primary:hover{filter:brightness(.96)}.btn-primary:disabled{background:var(--text-muted);box-shadow:none;cursor:not-allowed}.btn-secondary{background:var(--primary-light);color:var(--primary-dark)}.btn-outline{background:transparent;border:1.5px solid var(--border);color:var(--text)}.btn-outline:active{background:var(--bg-soft)}.btn-sm{padding:8px 16px;font-size:.875rem;width:auto}.tab-bar{position:fixed;bottom:0;left:50%;transform:translate(-50%);width:100%;max-width:430px;height:calc(64px + var(--safe-bottom));padding-bottom:var(--safe-bottom);background:#fffcf9eb;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-top:1px solid var(--border);display:flex;z-index:100}.tab-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;text-decoration:none;color:var(--tab-inactive);font-size:.7rem;font-weight:500;transition:color .2s ease}.tab-item.active{color:var(--tab-active);font-weight:600}.tab-icon{display:flex;align-items:center;justify-content:center;width:24px;height:24px;line-height:1}.tab-icon svg{display:block;width:24px;height:24px}.line-icon-slot{display:inline-flex;align-items:center;justify-content:center;color:inherit;flex-shrink:0}.line-icon-slot svg{display:block}.line-icon-slot--lg{margin-bottom:12px;color:var(--text-muted)}.line-icon-inline{display:inline-flex;align-items:center;gap:6px}.line-icon-inline svg{flex-shrink:0}.tab-label{line-height:1.2}.form-group{margin-bottom:20px}.form-label{display:block;font-size:.875rem;font-weight:600;margin-bottom:8px;color:var(--text-secondary)}.form-input{width:100%;padding:14px 16px;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-size:1rem;font-family:var(--font);background:var(--bg-card);color:var(--text);outline:none}.form-input:focus{border-color:var(--primary)}.form-input.demo-input{background:var(--bg-soft);color:var(--text-secondary);cursor:default}.form-select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%236a7268' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 16px center;padding-right:40px}.tag{display:inline-flex;align-items:center;padding:4px 10px;border-radius:20px;font-size:.75rem;font-weight:500}.tag-success{background:var(--success-light);color:var(--success)}.tag-warning{background:var(--warning-light);color:#9a8450}.tag-primary{background:var(--primary-light);color:var(--primary-dark)}.tag-muted{background:var(--bg-soft);color:var(--text-secondary)}.progress-bar{height:6px;background:var(--border);border-radius:3px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,var(--primary),var(--primary-mid));border-radius:3px;transition:width .5s ease}.progress-ring{width:120px;height:120px;border-radius:50%;border:6px solid var(--border);border-top-color:var(--primary);animation:spin 1.2s linear infinite;margin:0 auto}@keyframes spin{to{transform:rotate(360deg)}}.wizard-steps{display:flex;gap:6px;margin-bottom:24px}.wizard-step{flex:1;height:4px;border-radius:2px;background:var(--border)}.wizard-step.done,.wizard-step.active{background:var(--primary)}.wizard-step.active{opacity:.5}.upload-zone{border:2px dashed var(--border);border-radius:var(--radius);padding:32px 20px;text-align:center;cursor:pointer;background:var(--bg-card)}.upload-zone:active{border-color:var(--primary);background:var(--primary-light)}.photo-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:16px}.photo-item{aspect-ratio:1;border-radius:var(--radius-sm);background:linear-gradient(135deg,var(--accent-peach),var(--accent-warm));display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;color:var(--primary-dark)}.photo-item .remove{position:absolute;top:4px;right:4px;width:22px;height:22px;border-radius:50%;background:#00000080;color:#fff;border:none;font-size:.7rem;cursor:pointer}.style-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.style-card{padding:16px 8px;border:2px solid var(--border);border-radius:var(--radius-sm);text-align:center;cursor:pointer;background:var(--bg-card)}.style-card.selected{border-color:var(--primary);background:var(--primary-light)}.style-card .line-icon-slot{margin-bottom:6px;color:var(--primary-dark)}.style-card .label{font-size:.8rem;font-weight:600}.create-service-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.create-service-card{display:flex;flex-direction:column;align-items:flex-start;text-align:left;padding:14px 12px;border:2px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-card);cursor:pointer;transition:border-color .15s,background .15s}.create-service-card.selected{border-color:var(--primary);background:var(--primary-light)}.create-service-icon{display:flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:12px;background:var(--bg-soft);color:var(--primary-dark);margin-bottom:10px}.create-service-card.selected .create-service-icon{background:#ffffffd9}.create-service-title{font-size:.92rem;font-weight:600;color:var(--text);margin-bottom:4px}.create-service-sub{font-size:.72rem;color:var(--text-secondary);line-height:1.45;margin-bottom:8px}.create-service-price{font-size:.65rem;color:var(--primary-dark);font-weight:500}.create-service-grid--compact{gap:8px}.create-service-grid--compact .create-service-card{padding:10px}.create-service-grid--compact .create-service-icon{width:36px;height:36px;border-radius:10px;margin-bottom:8px}.create-service-grid--compact .create-service-title{font-size:.85rem;margin-bottom:2px}.create-service-grid--compact .create-service-sub{font-size:.68rem;line-height:1.35;margin-bottom:0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.create-flow-num{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:50%;background:var(--primary-light);color:var(--primary-dark);font-size:.72rem;font-weight:600;flex-shrink:0}.avatar{width:64px;height:64px;border-radius:50%;background:linear-gradient(135deg,var(--primary-mid),var(--primary-dark));display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.avatar-lg{width:100px;height:100px}.avatar-xl{width:140px;height:140px}.status-dot{width:8px;height:8px;border-radius:50%;display:inline-block}.status-dot.online{background:var(--success)}.status-dot.offline{background:var(--text-muted)}.chat-area{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:12px}.chat-bubble{max-width:80%;padding:12px 16px;border-radius:18px;font-size:.95rem;line-height:1.5}.chat-bubble.user{align-self:flex-end;background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%);color:#fff;border-bottom-right-radius:4px}.chat-bubble.assistant{align-self:flex-start;background:var(--bg-card);border:1px solid var(--border);border-bottom-left-radius:4px}.chat-input-bar{padding:12px 16px calc(12px + var(--safe-bottom));background:var(--bg-card);border-top:1px solid var(--border);display:flex;gap:10px;align-items:center}.voice-btn{width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%);color:#fff;border:none;cursor:pointer;flex-shrink:0;box-shadow:0 4px 16px var(--primary-glow);display:flex;align-items:center;justify-content:center}.voice-btn.recording{transform:scale(1.1);background:var(--primary-dark)}.digital-human{background:linear-gradient(180deg,var(--stage-from) 0%,var(--stage-to) 100%);display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;overflow:hidden}.digital-human.listening .wave{display:flex;gap:3px;margin-top:16px}.wave-bar{width:4px;height:20px;background:var(--primary);border-radius:2px;animation:wave .8s ease-in-out infinite}.wave-bar:nth-child(2){animation-delay:.1s;height:28px}.wave-bar:nth-child(3){animation-delay:.2s;height:16px}.wave-bar:nth-child(4){animation-delay:.3s;height:24px}.wave-bar:nth-child(5){animation-delay:.4s;height:18px}@keyframes wave{0%,to{transform:scaleY(.5)}50%{transform:scaleY(1)}}.slider-group{margin-bottom:20px}.slider-header{display:flex;justify-content:space-between;margin-bottom:8px;font-size:.875rem}.slider{width:100%;accent-color:var(--primary)}.checkbox-row{display:flex;align-items:flex-start;gap:10px;margin-bottom:12px;font-size:.875rem;line-height:1.5;cursor:pointer}.checkbox-row input{margin-top:3px;accent-color:var(--primary)}.splash{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;background:linear-gradient(165deg,var(--bg) 0%,var(--primary-light) 45%,var(--accent-peach) 100%);padding:40px 32px;text-align:center}.splash--login{position:relative;min-height:100vh;height:100%;padding:0;overflow:hidden}.splash-content{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:calc(100% - 48px);max-width:320px;display:flex;flex-direction:column;align-items:center;text-align:center}.splash-form{width:100%}.splash-logo{width:100px;height:100px;border-radius:28px;background:linear-gradient(135deg,var(--primary-mid) 0%,var(--primary-dark) 100%);display:flex;align-items:center;justify-content:center;color:#fff;margin-bottom:20px;box-shadow:0 10px 36px var(--primary-glow);flex-shrink:0}.splash h1{font-size:2rem;margin-bottom:8px}.splash .slogan{color:var(--text-secondary);font-size:.95rem;margin-bottom:28px;line-height:1.6}.robot-screen{aspect-ratio:4/3;border-radius:var(--radius);overflow:hidden;border:4px solid var(--stage-from);background:var(--stage-to);position:relative}.robot-status-bar{position:absolute;top:8px;left:12px;right:12px;display:flex;justify-content:space-between;font-size:.7rem;color:#fff9;z-index:2}.robot-hint{position:absolute;bottom:12px;left:0;right:0;text-align:center;font-size:.75rem;color:#ffffff80}.list-item{display:flex;align-items:center;gap:14px;padding:14px 0;border-bottom:1px solid var(--border)}.list-item:last-child{border-bottom:none}.empty-state{text-align:center;padding:48px 24px;color:var(--text-muted)}.empty-state .line-icon-slot--lg{margin-left:auto;margin-right:auto}.toast{position:fixed;top:72px;left:50%;transform:translate(-50%);background:#3a4038e0;color:#fff;padding:10px 20px;border-radius:50px;font-size:.875rem;z-index:200;animation:fadeIn .3s;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}@keyframes fadeIn{0%{opacity:0;transform:translate(-50%) translateY(-8px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.bottom-actions{position:fixed;bottom:0;left:50%;transform:translate(-50%);width:100%;max-width:430px;padding:16px 20px calc(16px + var(--safe-bottom));background:#f7f5f0eb;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-top:1px solid var(--border);display:flex;flex-direction:column;gap:10px;z-index:50}.page-with-bottom{padding-bottom:calc(120px + var(--safe-bottom))}.home-hero-brand{font-size:1.1rem;font-weight:700;color:var(--primary-dark);margin-bottom:6px}.home-hero-slogan{font-size:.95rem;line-height:1.6;color:var(--text-secondary)}.home-flow-steps{display:flex;flex-wrap:wrap;gap:8px}.home-flow-step{display:inline-flex;align-items:center;gap:6px;font-size:.8rem;padding:6px 12px;border-radius:20px;background:var(--bg-card);color:var(--text-secondary);border:1px solid var(--border)}.hall-grid{display:flex;flex-direction:column;gap:14px}.hall-card{position:relative;border-radius:var(--radius);padding:20px 18px 18px;cursor:pointer;transition:transform .15s,box-shadow .15s;border:1px solid transparent;overflow:hidden}.hall-card:active{transform:scale(.98)}.hall-card--pet{background:linear-gradient(135deg,var(--hall-pet-from) 0%,var(--hall-pet-to) 100%);border-color:var(--hall-pet-border)}.hall-card--memorial{background:linear-gradient(135deg,var(--hall-memorial-from) 0%,var(--hall-memorial-to) 100%);border-color:var(--hall-memorial-border)}.hall-card--love{background:linear-gradient(135deg,var(--hall-love-from) 0%,var(--hall-love-to) 100%);border-color:var(--hall-love-border)}.hall-card--future{background:linear-gradient(135deg,var(--hall-future-from) 0%,var(--hall-future-to) 100%);border-color:var(--hall-future-border)}.hall-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.hall-card-tag{font-size:.7rem;font-weight:600;padding:3px 10px;border-radius:20px;background:#ffffffa6;color:var(--text-secondary)}.hall-card-count{font-size:.75rem;color:var(--text-secondary);background:#ffffffa6;padding:3px 10px;border-radius:20px}.hall-card-icon{display:flex;align-items:center;margin-bottom:8px;line-height:1;color:var(--text-secondary)}.hall-card-title{font-size:1.15rem;margin-bottom:6px}.hall-card-desc{font-size:.82rem;color:var(--text-secondary);line-height:1.55;margin-bottom:12px;padding-right:24px}.hall-card-arrow{display:inline-flex;align-items:center;gap:4px;font-size:.8rem;font-weight:600;color:var(--text-secondary);margin-top:12px}.hall-works-showcase{margin-top:8px;margin-bottom:8px}.hall-works-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;gap:8px}.hall-works-label{font-size:.72rem;font-weight:600;color:var(--text-secondary);margin:0}.hall-works-scroll-hint{color:var(--primary-dark);background:none;border:none;cursor:pointer;padding:0;white-space:nowrap}.hall-works-scroll{display:flex;gap:10px;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;padding-bottom:4px;margin:0 -4px;padding-left:4px;padding-right:4px}.hall-works-scroll::-webkit-scrollbar{display:none}.hall-works-empty{padding:12px;border-radius:var(--radius-sm);background:#ffffff73;text-align:center;margin:8px 0}.hall-work-card{flex:0 0 148px;scroll-snap-align:start;border-radius:var(--radius-sm);background:#ffffffd9;border:1px solid rgba(255,255,255,.95);box-shadow:0 2px 12px #0000000d;overflow:hidden}.hall-work-media{position:relative;width:100%;aspect-ratio:3 / 4;background:var(--bg-soft);overflow:hidden;cursor:pointer}.hall-work-cover{width:100%;height:100%;object-fit:cover;display:block;transition:opacity .25s ease}.hall-work-cover--hidden{opacity:0}.hall-work-video{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover}.hall-work-play-icon{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:32px;height:32px;border-radius:50%;background:#ffffffe6;color:var(--primary-dark);font-size:.7rem;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow);pointer-events:none}.hall-work-duration{position:absolute;bottom:6px;right:6px;font-size:.58rem;font-weight:600;background:#0000008c;color:#fff;padding:2px 6px;border-radius:8px}.hall-work-generating{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#00000059;color:#fff;padding:12px}.hall-work-card-body{padding:8px 10px 10px}.hall-work-name{font-weight:600;font-size:.82rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:72px}.hall-work-meta{margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.hall-work-greeting{font-size:.68rem;line-height:1.4;color:var(--text-secondary);margin-bottom:8px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;min-height:2.8em}.hall-work-actions{display:flex;gap:6px}.hall-work-actions .btn-sm{padding:5px 0;font-size:.65rem;width:auto;flex:1;min-width:0}.hall-works-showcase--page{margin:0 0 20px;padding:14px;border-radius:var(--radius);background:var(--bg-soft)}.hall-works-showcase--page .hall-works-label{font-size:.85rem;color:var(--text)}.hall-works-scroll--grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;overflow:visible;margin:0;padding:0}.hall-works-scroll--grid .hall-work-card{flex:none;width:100%}.hall-works-scroll--grid .hall-work-name{max-width:none}.hall-works-scroll--grid .hall-work-greeting{min-height:auto;-webkit-line-clamp:2}.hall-card--pet .hall-card-arrow{color:var(--hall-pet-accent)}.hall-card--memorial .hall-card-arrow{color:var(--hall-memorial-accent)}.hall-card--love .hall-card-arrow{color:var(--hall-love-accent)}.hall-card--future .hall-card-arrow{color:var(--hall-future-accent)}.device-bar{padding:14px 16px}.hall-hero{border-radius:var(--radius);padding:28px 20px;text-align:center}.hall-hero--pet{background:linear-gradient(135deg,var(--hall-pet-from) 0%,var(--hall-pet-to) 100%)}.hall-hero--memorial{background:linear-gradient(135deg,var(--hall-memorial-from) 0%,var(--hall-memorial-to) 100%)}.hall-hero--love{background:linear-gradient(135deg,var(--hall-love-from) 0%,var(--hall-love-to) 100%)}.hall-hero--future{background:linear-gradient(135deg,var(--hall-future-from) 0%,var(--hall-future-to) 100%)}.hall-hero-icon{display:flex;align-items:center;justify-content:center;margin-bottom:8px;color:inherit}.hall-hero-tag{font-size:.75rem;font-weight:600;color:var(--text-secondary);margin-bottom:8px}.hall-hero-desc{font-size:.9rem;color:var(--text-secondary);line-height:1.6}.hall-badge{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;border-radius:50px;font-size:.85rem;font-weight:600;margin-bottom:20px}.hall-badge--pet{background:var(--hall-pet-badge);color:var(--hall-pet-accent)}.hall-badge--memorial{background:var(--hall-memorial-badge);color:var(--hall-memorial-accent)}.hall-badge--love{background:var(--hall-love-badge);color:var(--hall-love-accent)}.hall-badge--future{background:var(--hall-future-badge);color:var(--hall-future-accent)}.photo-item--old{filter:sepia(.6) contrast(.85);opacity:.85}.photo-item--restored{box-shadow:0 0 0 2px var(--success)}.photo-restore-badge{position:absolute;top:4px;left:4px;font-size:.55rem;background:var(--success);color:#fff;padding:2px 5px;border-radius:4px}.restore-banner{background:var(--warning-light);border-color:#e8d8b0}.restore-compare-grid{display:grid;grid-template-columns:1fr auto 1fr;gap:12px;align-items:center}.restore-compare-photo{aspect-ratio:1;border-radius:var(--radius-sm);background:linear-gradient(135deg,var(--accent-peach),var(--accent-warm));display:flex;align-items:center;justify-content:center;margin-bottom:6px;color:var(--primary-dark)}.restore-compare-photo.old{filter:sepia(.7) blur(1px) contrast(.8)}.restore-compare-photo.restored{background:linear-gradient(135deg,var(--primary-light),var(--primary-mid));filter:none}.restore-compare-label{font-size:.7rem;font-weight:600;color:var(--text-secondary)}.restore-compare-arrow{font-size:1.25rem;color:var(--text-muted);text-align:center}.video-gen-preview{position:relative;width:120px;height:120px;margin:0 auto;border-radius:50%;background:linear-gradient(135deg,var(--stage-from),var(--stage-to));display:flex;align-items:center;justify-content:center;overflow:hidden}.video-gen-face{font-size:3rem;z-index:1}.video-gen-scan{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,transparent 40%,var(--stage-scan) 50%,transparent 60%);animation:scan 1.5s linear infinite}@keyframes scan{0%{transform:translateY(-100%)}to{transform:translateY(100%)}}.video-preview-card{padding:0;overflow:hidden}.video-avatar-player{position:relative;background:linear-gradient(180deg,var(--stage-from) 0%,var(--stage-to) 100%);padding:32px 20px;text-align:center;min-height:200px;display:flex;flex-direction:column;align-items:center;justify-content:center}.video-avatar-face{display:flex;align-items:center;justify-content:center;line-height:1;color:var(--primary-dark)}.video-avatar-badge{margin-top:12px;font-size:.75rem;color:var(--success);background:#6db8922e;padding:4px 12px;border-radius:20px}.video-avatar-caption{margin-top:12px;color:#ffffffbf;font-size:.85rem;padding:0 16px}.memorial-video-player{position:relative;width:100%;background:var(--stage-to);overflow:hidden}.memorial-video{width:100%;height:100%;min-height:200px;max-height:320px;object-fit:cover;display:block;background:#000}.memorial-video-loading{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--stage-to);z-index:1}.memorial-video-badge{position:absolute;top:12px;left:12px;z-index:2;margin-top:0!important}.memorial-video-caption{position:absolute;bottom:12px;left:0;right:0;z-index:2;text-align:center;margin-top:0!important;text-shadow:0 1px 8px rgba(0,0,0,.8)}.memorial-video-play-btn{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:56px;height:56px;border-radius:50%;border:none;background:#ffffffeb;color:var(--primary-dark);font-size:1.25rem;cursor:pointer;z-index:2;box-shadow:var(--shadow-soft);display:flex;align-items:center;justify-content:center}.memorial-video-pause-hint{position:absolute;bottom:48px;left:50%;transform:translate(-50%);z-index:2;background:#00000073;color:#fff;border:none;border-radius:20px;padding:4px 12px;font-size:.7rem;cursor:pointer}.video-chat-status-overlay,.video-chat-lips-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#00000073;z-index:3;color:#ffffffd9;pointer-events:none}.video-chat-lips-overlay{background:transparent;justify-content:flex-end;padding-bottom:48px}.video-chat-player .memorial-video-player{height:100%}.video-chat-player .memorial-video{max-height:none;min-height:240px}.video-chat-page{display:flex;flex-direction:column;height:100vh;padding-bottom:0}.video-chat-stage{flex-shrink:0;background:var(--stage-to)}.video-chat-player{position:relative;aspect-ratio:4/3;max-height:45vh;background:linear-gradient(180deg,var(--stage-from) 0%,var(--stage-to) 100%);display:flex;align-items:center;justify-content:center}.video-chat-avatar{display:flex;flex-direction:column;align-items:center;justify-content:center;transition:transform .3s}.video-chat-avatar.speaking{transform:scale(1.02)}.video-chat-face{font-size:5rem;line-height:1}.video-chat-status{margin-top:16px;text-align:center;color:#fff9;font-size:.85rem}.video-chat-status .text-xs{color:#fff6;margin-top:4px}.video-chat-subtitle{margin-top:16px;padding:0 24px;color:#ffffffd9;font-size:.9rem;line-height:1.5;text-align:center;max-width:320px}.video-chat-overlay{position:absolute;top:12px;left:12px}.video-live-tag{display:inline-flex;align-items:center;gap:6px;font-size:.7rem;color:#ffffffb3;background:#0006;padding:4px 10px;border-radius:20px}.video-chat-messages{flex:1;overflow-y:auto;padding:12px 16px;display:flex;flex-direction:column;gap:10px;background:var(--bg)}.lip-sync{display:flex;gap:3px;align-items:flex-end;height:16px;margin-top:8px}.lip-sync-bar{width:4px;background:var(--primary);border-radius:2px;animation:lipSync .4s ease-in-out infinite}.lip-sync-bar:nth-child(1){height:8px;animation-delay:0s}.lip-sync-bar:nth-child(2){height:14px;animation-delay:.1s}.lip-sync-bar:nth-child(3){height:10px;animation-delay:.2s}.lip-sync-bar:nth-child(4){height:16px;animation-delay:.15s}.lip-sync-bar:nth-child(5){height:8px;animation-delay:.05s}@keyframes lipSync{0%,to{transform:scaleY(.6)}50%{transform:scaleY(1)}}.video-chat-stage--speaking .video-chat-player{box-shadow:inset 0 0 40px var(--stage-glow)}.billing-tabs{display:flex;gap:8px;margin-bottom:16px}.billing-tabs--sm .billing-tab{padding:6px 12px;font-size:.8rem}.billing-tab{flex:1;padding:10px 8px;border:1.5px solid var(--border);border-radius:50px;background:var(--bg-card);font-size:.875rem;font-weight:600;font-family:var(--font);color:var(--text-secondary);cursor:pointer;transition:all .15s}.billing-tab.active{border-color:var(--primary);background:var(--primary-light);color:var(--primary-dark)}.membership-card{padding:12px}.membership-plan{padding:14px;border-radius:var(--radius-sm);border:1.5px solid transparent;cursor:pointer;margin-bottom:8px}.membership-plan:last-child{margin-bottom:0}.membership-plan.selected{border-color:var(--primary);background:var(--primary-light)}.membership-includes{list-style:none;padding:0;margin:0}.membership-includes li{padding:2px 0 2px 14px;position:relative}.membership-includes li:before{content:"·";position:absolute;left:0;color:var(--primary)}.hall-service-price{text-align:right;flex-shrink:0}.price-current{font-weight:700;color:var(--primary-dark);font-size:1.05rem}.price-original{font-size:.75rem;color:var(--text-muted);text-decoration:line-through;margin-left:6px}.shop-categories{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}.shop-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.shop-product{padding:14px;position:relative;display:flex;flex-direction:column}.shop-product-tag{position:absolute;top:10px;right:10px;font-size:.65rem;background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%);color:#fff;padding:2px 8px;border-radius:20px}.shop-product-emoji{font-size:2.5rem;text-align:center;margin-bottom:8px}.shop-product-cover{width:100%;aspect-ratio:1;border-radius:var(--radius-sm);overflow:hidden;margin-bottom:10px;background:var(--bg-soft)}.shop-product-cover img{width:100%;height:100%;object-fit:cover;display:block}.shop-product-name{font-weight:600;font-size:.9rem;margin-bottom:4px}.shop-product-desc{flex:1;line-height:1.4;margin-bottom:8px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.shop-product-price{margin-top:auto}.order-list-item{margin-bottom:10px}.order-list-price{margin-top:8px;font-weight:600;font-size:.95rem;color:var(--primary-dark)}.profile-quota-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.profile-quota-item{text-align:center;padding:12px 8px;background:var(--bg-soft);border-radius:var(--radius-sm);border:1px solid var(--border)}.profile-quota-item span:first-child{display:inline-flex;justify-content:center}.profile-quota-item p{margin-top:4px}.share-actions{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.share-action-item{display:flex;flex-direction:column;align-items:center;gap:8px;padding:12px 8px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;transition:background .15s,border-color .15s}.share-action-item:active{background:var(--primary-light);border-color:var(--primary-mid)}.share-action-icon{display:flex;align-items:center;justify-content:center;color:var(--primary-dark)}.home-hero{background:linear-gradient(135deg,var(--primary-light) 0%,var(--bg-card) 55%,var(--accent-peach) 100%)!important;border:1px solid var(--border)!important}.hall-card-story{margin:8px 0 12px;line-height:1.5;font-style:italic}.companion-avatar{display:flex;align-items:center;justify-content:center;border-radius:50%;flex-shrink:0;color:#fffffff2;box-shadow:var(--shadow)}.companion-avatar--sm{width:36px;height:36px}.companion-avatar--md{width:56px;height:56px}.companion-avatar--lg{width:72px;height:72px}.companion-avatar--xl{width:96px;height:96px}.companion-avatar--pet{background:linear-gradient(135deg,var(--hall-pet-from),var(--hall-pet-to))}.companion-avatar--memorial{background:linear-gradient(135deg,var(--hall-memorial-from),var(--hall-memorial-to))}.companion-avatar--love{background:linear-gradient(135deg,var(--hall-love-from),var(--hall-love-to))}.companion-avatar--future{background:linear-gradient(135deg,var(--hall-future-from),var(--hall-future-to))}.recent-works-scroll{display:flex;gap:12px;overflow-x:auto;padding-bottom:4px}.recent-work-card{min-width:120px;padding:14px;text-align:center;flex-shrink:0}.notif-btn{position:relative}.notif-badge{position:absolute;top:2px;right:2px;min-width:16px;height:16px;padding:0 4px;background:var(--danger);color:#fff;font-size:.65rem;font-weight:700;border-radius:10px;display:flex;align-items:center;justify-content:center}.notif-panel .notif-item{border-bottom:1px solid var(--border)}.notif-panel .notif-item:last-child{border-bottom:none}.detail-meta-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.companion-detail-hero{display:flex;flex-direction:column;align-items:center;justify-content:center}.companion-detail-hero-wrap{position:relative}.companion-detail-hero-wrap .video-avatar-badge{position:absolute;bottom:12px;left:50%;transform:translate(-50%);z-index:2}.detail-media-hero{position:relative;width:100%;aspect-ratio:3 / 4;max-height:360px;background:var(--bg-soft);overflow:hidden}.detail-media-hero--generating{display:flex;align-items:center;justify-content:center}.detail-media-main{width:100%;height:100%;object-fit:cover;display:block}.detail-media-main--dim{opacity:.45}.detail-media-thumbs{display:flex;gap:8px;overflow-x:auto;padding-bottom:4px;-webkit-overflow-scrolling:touch}.detail-media-thumbs::-webkit-scrollbar{display:none}.detail-media-thumb{flex:0 0 64px;width:64px;height:64px;padding:0;border:2px solid transparent;border-radius:var(--radius-sm);overflow:hidden;cursor:pointer;background:var(--bg-soft)}.detail-media-thumb.active{border-color:var(--primary)}.detail-media-thumb img{width:100%;height:100%;object-fit:cover;display:block}.photo-item-name{position:absolute;bottom:22px;left:4px;right:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:.55rem;text-align:center}.photo-item-date{position:absolute;bottom:4px;left:0;right:0;text-align:center;font-size:.5rem}.photo-item-caption{position:absolute;bottom:14px;left:2px;right:2px;text-align:center;font-size:.5rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.photo-source-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px}.photo-source-btn{display:flex;flex-direction:column;align-items:center;gap:4px;padding:16px 10px;border:1.5px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-card);cursor:pointer;font-family:inherit;transition:border-color .15s,background .15s}.photo-source-btn:active:not(:disabled){border-color:var(--primary);background:var(--primary-light)}.photo-source-btn:disabled{opacity:.7;cursor:wait}.photo-source-icon{display:flex;align-items:center;justify-content:center;color:var(--primary-dark)}.photo-source-label{font-size:.9rem;font-weight:600;color:var(--text)}.photo-picker-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;z-index:300;display:flex;align-items:flex-end;justify-content:center}.phone-screen .photo-picker-overlay{position:absolute}.photo-picker-sheet{width:100%;max-width:430px;max-height:85vh;background:var(--bg-card);border-radius:16px 16px 0 0;display:flex;flex-direction:column;animation:sheetUp .25s ease}@keyframes sheetUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.photo-picker-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--border);flex-shrink:0}.photo-picker-title{font-weight:600;font-size:1rem}.photo-picker-cancel,.photo-picker-done{background:none;border:none;font-family:inherit;font-size:.9rem;cursor:pointer;padding:4px 8px}.photo-picker-cancel{color:var(--text-secondary)}.photo-picker-done{color:var(--primary-dark);font-weight:600}.photo-picker-done:disabled{color:var(--text-muted);cursor:not-allowed}.photo-picker-hint{padding:8px 16px 0;flex-shrink:0}.photo-picker-body{overflow-y:auto;padding:12px 16px 24px;flex:1}.photo-picker-group{margin-bottom:16px}.photo-picker-group-label{font-size:.8rem;font-weight:600;color:var(--text-secondary);margin-bottom:8px}.photo-picker-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:4px}.photo-picker-cell{aspect-ratio:1;border:2px solid transparent;border-radius:4px;padding:0;position:relative;cursor:pointer;background:linear-gradient(135deg,var(--accent-peach),var(--accent-warm));overflow:hidden}.photo-picker-cell.selected{border-color:var(--primary)}.photo-picker-cell.added{opacity:.45;cursor:not-allowed}.photo-picker-thumb{font-size:1.5rem;display:flex;align-items:center;justify-content:center;width:100%;height:100%}.photo-picker-check{position:absolute;top:4px;right:4px;width:20px;height:20px;border-radius:50%;border:2px solid #fff;background:#00000040;color:#fff;font-size:.65rem;display:flex;align-items:center;justify-content:center}.photo-picker-check.on{background:var(--primary);border-color:var(--primary)}.photo-picker-old-tag{position:absolute;bottom:4px;left:4px;font-size:.55rem;background:#00000080;color:#fff;padding:1px 4px;border-radius:3px}.photo-picker-added-tag{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-size:.65rem;font-weight:600;color:#fff;background:#00000059}.chat-bubble{display:flex;flex-direction:column;gap:4px}.chat-bubble-time{opacity:.75;align-self:flex-end}.video-chat-quota-bar{display:flex;justify-content:center;gap:8px;padding:6px 16px;background:var(--bg-soft);border-bottom:1px solid var(--border)}.video-chat-avatar-img{background:transparent!important;box-shadow:none!important}.device-bound-avatar{margin-top:8px}.dist-hero{background:linear-gradient(135deg,var(--primary-dark) 0%,var(--hall-memorial-accent) 100%);color:#fff;border:none}.dist-amount{font-size:2rem;font-weight:700;margin-top:4px}.payment-lock-preview{position:relative;min-height:160px}.payment-lock-preview-inner{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:32px 16px;filter:blur(2px);opacity:.55;pointer-events:none;-webkit-user-select:none;user-select:none}.payment-lock-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;background:#fffcf7b8;color:var(--primary-dark);font-weight:600}.payment-lock-hero .tag-warning{display:inline-block}.service-tier-steps{display:flex;gap:4px;margin-bottom:14px;overflow-x:auto;padding-bottom:4px}.service-tier-step{flex:1;min-width:0;display:flex;flex-direction:column;align-items:center;gap:4px;opacity:.45}.service-tier-step.done,.service-tier-step.current{opacity:1}.service-tier-dot{width:22px;height:22px;border-radius:50%;border:1.5px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:.65rem;font-weight:600;background:var(--bg-soft)}.service-tier-step.done .service-tier-dot{background:var(--primary-light);border-color:var(--primary);color:var(--primary-dark)}.service-tier-step.current .service-tier-dot{background:var(--primary);border-color:var(--primary);color:#fff}.service-tier-label{font-size:.6rem;color:var(--text-muted);text-align:center;line-height:1.2}.service-tier-step.current .service-tier-label{color:var(--primary-dark);font-weight:600}.service-upgrade-banner{margin-bottom:12px;padding:16px;border-radius:var(--radius);background:linear-gradient(135deg,var(--primary-light) 0%,#fff 100%);border:1px solid rgba(168,146,120,.25)}.service-upgrade-banner--compact{padding:14px}.service-upgrade-body{display:flex;gap:12px;align-items:flex-start;margin-bottom:12px}.service-upgrade-icon{flex-shrink:0;width:44px;height:44px;border-radius:50%;background:#fff;display:flex;align-items:center;justify-content:center;color:var(--primary-dark);box-shadow:0 2px 8px #0000000f}.service-upgrade-banner--compact .service-upgrade-icon{width:36px;height:36px}.service-upgrade-title{font-weight:600;margin-bottom:4px}.service-upgrade-cta{width:100%;justify-content:center}
