:root{--ink: #111827;--muted: #697386;--soft: #f6faf7;--surface: #ffffff;--line: #e8edf3;--mist: #e5f3ea;--lavender: #ecebff;--indigo: #6366f1;--wellness: #5f9278;--amber: #d49a3a;--danger: #b44a42;--shadow-calm: 0 12px 32px rgba(15, 23, 42, .1);--shadow-float: 0 18px 46px rgba(99, 102, 241, .26);font-family:ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,SF Pro Display,Segoe UI,sans-serif}*{box-sizing:border-box}body{margin:0;min-height:100vh;overflow-x:hidden;background:radial-gradient(circle at 18% 8%,rgba(236,235,255,.95),transparent 30%),radial-gradient(circle at 88% 4%,rgba(229,243,234,.85),transparent 28%),linear-gradient(135deg,#eef3ff,#f6faf7 42%,#fff);color:var(--ink)}body.startup-active{overflow:hidden}body:before{position:fixed;top:0;right:0;bottom:0;left:0;z-index:-1;background:radial-gradient(circle at 42% 28%,rgba(255,255,255,.72),transparent 34%),radial-gradient(circle at 60% 80%,rgba(229,243,234,.55),transparent 32%);content:"";opacity:.9;animation:ambient-wash 16s ease-in-out infinite alternate}button,input,select,textarea{font:inherit}button{cursor:pointer}button,a,select,textarea,input{transition:border-color .2s ease,box-shadow .2s ease,color .2s ease,background .2s ease,transform .2s ease,opacity .2s ease}.icon-glyph{width:1em;height:1em;flex:0 0 auto;fill:none;stroke:currentColor;stroke-linecap:round;stroke-linejoin:round;stroke-width:2}.transport-icon-img{display:block;width:1.18em;height:1.18em;flex:0 0 auto;object-fit:contain}h1,h2,p{margin:0}h1{font-size:2rem;line-height:1.05;font-weight:700}h2{font-size:1.2rem;line-height:1.2}.app-shell{min-height:100vh;padding:24px}.app-shell.booting{min-height:100vh}.app-surface{position:relative;width:min(1120px,100%);min-height:calc(100vh - 48px);margin:0 auto;overflow:hidden;border:1px solid rgba(232,237,243,.9);border-radius:28px;background:#f6faf7db;box-shadow:0 28px 90px #0f172a24;-webkit-backdrop-filter:blur(24px) saturate(1.12);backdrop-filter:blur(24px) saturate(1.12)}.app-surface:before{position:absolute;top:0;right:0;bottom:0;left:0;z-index:0;background:linear-gradient(140deg,rgba(255,255,255,.42),transparent 42%),radial-gradient(circle at 85% 18%,rgba(236,235,255,.54),transparent 20%);content:"";pointer-events:none}.app-surface>*{position:relative;z-index:1}.startup-splash{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;display:grid;place-items:center;align-content:center;gap:18px;overflow:hidden;background:radial-gradient(circle at 48% 38%,rgba(255,255,255,.92),transparent 24%),radial-gradient(circle at 28% 26%,rgba(236,235,255,.74),transparent 30%),radial-gradient(circle at 78% 70%,rgba(229,243,234,.72),transparent 32%),linear-gradient(135deg,#f5f8ff,#f8fbf8 52%,#fff)}.startup-splash:before,.startup-splash:after{position:absolute;inset:auto -8% 20% -8%;height:110px;border-radius:999px;background:linear-gradient(90deg,transparent,rgba(95,146,120,.14),rgba(99,102,241,.12),transparent);content:"";opacity:.72;transform:rotate(-6deg);animation:startup-route-drift 3.8s ease-in-out infinite alternate}.startup-splash:after{inset:20% -12% auto -12%;height:82px;opacity:.36;transform:rotate(8deg);animation-delay:.5s}.startup-icon{position:relative;z-index:2;width:clamp(112px,16vw,156px);height:clamp(112px,16vw,156px);object-fit:contain;filter:drop-shadow(0 24px 48px rgba(99,102,241,.22));animation:startup-breathe 2.7s ease-in-out infinite,startup-settle 1.8s cubic-bezier(.2,.82,.2,1) both}.startup-orbit{position:absolute;z-index:1;width:clamp(190px,26vw,270px);height:clamp(190px,26vw,270px);border-radius:50%;opacity:.86}.startup-ring,.startup-route,.startup-node{position:absolute;display:block}.startup-ring{top:18%;right:18%;bottom:18%;left:18%;border:1px solid rgba(99,102,241,.14);border-radius:50%;animation:startup-ring 3.2s ease-in-out infinite}.startup-ring.two{top:28%;right:28%;bottom:28%;left:28%;border-color:#5f927824;animation-delay:.7s}.startup-route{left:8%;right:8%;top:53%;height:4px;border-radius:999px;background:linear-gradient(90deg,transparent,rgba(95,146,120,.32),rgba(99,102,241,.24),transparent);transform:rotate(-10deg);animation:startup-line 3s ease-in-out infinite}.startup-node{width:11px;height:11px;border:2px solid #fff;border-radius:50%;box-shadow:0 10px 24px #0f172a1f}.startup-node.a{left:22%;top:49%;background:var(--indigo);animation:startup-node 2.6s ease-in-out infinite}.startup-node.b{right:19%;top:42%;background:var(--wellness);animation:startup-node 2.6s ease-in-out .5s infinite}.startup-copy{position:relative;z-index:2;display:grid;gap:6px;text-align:center;animation:startup-settle-copy 1.8s cubic-bezier(.2,.82,.2,1) both}.startup-copy strong{color:var(--ink);font-size:1rem;letter-spacing:0;animation:startup-breathe 2.7s ease-in-out infinite}.startup-copy span{color:var(--muted);font-size:.9rem;font-weight:700}.splash-fade-enter-active,.splash-fade-leave-active{transition:opacity .55s ease,filter .55s ease}.splash-fade-enter-from,.splash-fade-leave-to{opacity:0;filter:blur(10px)}.journey-background{position:absolute;top:0;right:0;bottom:0;left:0;z-index:0;overflow:hidden;border-radius:inherit;pointer-events:none}.journey-background span{position:absolute;display:block}.journey-grid{top:8%;right:4%;bottom:10%;left:4%;opacity:.28;background:linear-gradient(90deg,rgba(95,146,120,.08) 1px,transparent 1px),linear-gradient(0deg,rgba(99,102,241,.055) 1px,transparent 1px);background-size:64px 64px;-webkit-mask-image:radial-gradient(circle at 52% 42%,#000 0%,transparent 62%);mask-image:radial-gradient(circle at 52% 42%,#000 0%,transparent 62%)}.journey-route{height:10px;border-radius:999px;opacity:.34;background:linear-gradient(90deg,transparent,rgba(95,146,120,.46),rgba(99,102,241,.28),transparent),repeating-linear-gradient(90deg,transparent 0 20px,rgba(255,255,255,.74) 20px 28px);filter:blur(.1px)}.journey-route.one{left:-9%;right:42%;bottom:20%;transform:rotate(-8deg)}.journey-route.two{left:50%;right:-11%;top:34%;opacity:.24;transform:rotate(14deg)}.journey-node{width:13px;height:13px;border:3px solid rgba(255,255,255,.9);border-radius:50%;box-shadow:0 12px 28px #0f172a14;opacity:.62}.journey-node.a{left:14%;bottom:24%;background:var(--indigo)}.journey-node.b{left:38%;bottom:29%;background:var(--amber)}.journey-node.c{right:18%;top:35%;background:var(--wellness)}.journey-compass{right:7%;bottom:18%;width:170px;height:170px;border:1px solid rgba(99,102,241,.11);border-radius:50%;opacity:.5}.journey-compass:before,.journey-compass:after{position:absolute;top:24px;right:24px;bottom:24px;left:24px;border:1px dashed rgba(95,146,120,.12);border-radius:50%;content:""}.journey-compass:after{top:58px;right:58px;bottom:58px;left:58px;border-style:solid;border-color:#d49a3a1f}.journey-ticket{left:7%;top:20%;width:128px;height:76px;border:1px solid rgba(232,237,243,.82);border-radius:18px;background:radial-gradient(circle at 0 50%,rgba(246,250,247,.96) 0 10px,transparent 11px),radial-gradient(circle at 100% 50%,rgba(246,250,247,.96) 0 10px,transparent 11px),linear-gradient(135deg,#ffffff94,#ecebff38);box-shadow:0 18px 44px #0f172a0e;opacity:.5;transform:rotate(-8deg)}.journey-ticket:before,.journey-ticket:after{position:absolute;left:22px;right:22px;height:7px;border-radius:999px;background:#5f92781f;content:""}.journey-ticket:before{top:22px}.journey-ticket:after{top:38px;right:42px;background:#6366f11a}.screen{min-height:calc(100vh - 48px);padding:32px clamp(18px,4vw,42px) 120px}.screen-fade-enter-active,.screen-fade-leave-active{transition:opacity .26s ease,transform .3s ease,filter .3s ease}.screen-fade-enter-from{opacity:0;filter:blur(8px);transform:translateY(10px) scale(.992)}.screen-fade-leave-to{opacity:0;filter:blur(8px);transform:translateY(-8px) scale(.996)}.home-screen{display:block;max-width:680px;margin:0 auto}.home-header{margin-bottom:18px}.home-header,.screen-header,.panel-head,.place-main,.card-footer,.action-row{display:flex;align-items:center}.home-header,.screen-header,.card-footer{justify-content:space-between;gap:14px}.screen-header{min-height:44px;justify-content:flex-end}.screen-header>div{display:flex;flex-direction:column;gap:4px}.muted{color:var(--muted);font-size:.9rem;line-height:1.25}.greeting-line{display:inline-flex;flex-wrap:wrap;align-items:baseline;gap:6px}.greeting-line b{color:var(--ink);font-weight:850}.icon-button,.back-button{position:relative;display:grid;place-items:center;width:44px;height:44px;flex:0 0 auto;border:0;border-radius:50%;background:var(--surface);color:var(--ink);box-shadow:var(--shadow-calm);font-weight:800}.icon-button i,.bottom-nav i{position:absolute;display:grid;place-items:center;min-width:18px;height:18px;padding:0 5px;border-radius:999px;background:var(--indigo);color:#fff;font-size:.68rem;font-style:normal}.icon-button i{right:-3px;top:-3px}.back-button{position:fixed;left:max(52px,calc((100vw - 1120px)/2 + 42px));top:max(28px,calc(env(safe-area-inset-top) + 52px));z-index:160;font-size:1.7rem}.app-back-button{pointer-events:auto}.ambient-toggle{position:fixed;left:max(28px,calc((100vw - 1120px)/2 + 28px));bottom:28px;z-index:120;display:inline-flex;align-items:center;gap:7px;min-height:38px;border:1px solid rgba(232,237,243,.78);border-radius:999px;background:#ffffffb8;color:var(--muted);padding:0 12px;box-shadow:0 12px 28px #0f172a14;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);font-size:.78rem;font-weight:850;opacity:.72}.ambient-toggle span{overflow:hidden;max-width:0;opacity:0;white-space:nowrap;transition:max-width .24s ease,opacity .2s ease}.ambient-toggle.active{border-color:#5f927833;background:#e5f3eadb;color:var(--wellness);opacity:.94}.next-card,.choice-panel,.place-card,.saved-card,.auth-panel,.profile-card,.profile-section,.admin-login-card,.admin-panel,.admin-stat,.detail-map-card,.detail-copy,.reason-list div,.empty-state{border-radius:26px;background:#ffffffeb;box-shadow:var(--shadow-calm);transition:box-shadow .24s ease,transform .24s ease,background .24s ease}.next-card{margin-top:22px;padding:18px}.card-kicker{display:flex;justify-content:space-between;gap:12px;margin-bottom:16px;color:var(--indigo);font-size:.72rem;font-weight:800}.card-kicker span{letter-spacing:.18em}.soft-map{position:relative;height:132px;overflow:hidden;border-radius:24px;background:linear-gradient(135deg,#e5f3eaf2,#ffffffe6 48%,#ecebfff2),linear-gradient(90deg,rgba(17,24,39,.05) 1px,transparent 1px),linear-gradient(0deg,rgba(17,24,39,.05) 1px,transparent 1px);background-size:auto,26px 26px,26px 26px}.soft-map.large{height:220px}.route-line{position:absolute;left:-10%;top:54%;width:120%;height:12px;border-radius:999px;background:#5f92785c;transform:rotate(-10deg)}.pin{position:absolute;width:18px;height:18px;border:4px solid #fff;border-radius:50%;background:var(--indigo);box-shadow:0 8px 22px #6366f159}.pin.one{left:20%;top:52%}.pin.two{right:24%;top:34%;background:var(--wellness)}.soft-map span{position:absolute;left:16px;bottom:14px;padding:7px 10px;border-radius:999px;background:#ffffffe0;color:var(--muted);font-size:.78rem;font-weight:800}.next-card h2,.detail-copy,.reason-list,.choice-panel{margin-top:18px}.next-card p,.detail-copy p,.saved-card p,.place-card p,.empty-state p{margin-top:8px;color:var(--muted);line-height:1.55}.metric-row,.badge-row{display:flex;flex-wrap:wrap;gap:8px;margin-top:14px}.metric-row>span,.badge-row>span,.score-pill{display:inline-flex;align-items:center;min-height:30px;padding:6px 10px;border-radius:999px;background:#f1f5f9;color:var(--muted);font-size:.78rem;font-weight:800}.metric-row>span:first-child,.score-pill{background:#6366f11f;color:var(--indigo)}.badge-chip{gap:6px}.badge-chip strong,.badge-chip small{line-height:1}.badge-chip small{color:inherit;opacity:.78}.commute-badge,.commute-chip{background:#6366f11a;color:var(--indigo)}.commute-badge{gap:7px}.commute-badge .icon-glyph{width:18px;height:18px;stroke-width:2.35}.commute-badge .transport-icon-img{width:20px;height:20px}.commute-chip .icon-glyph,.commute-inline .icon-glyph{width:20px;height:20px;stroke-width:2.35}.commute-chip .transport-icon-img,.commute-inline .transport-icon-img{width:22px;height:22px}.suitability-chip{background:#5f92781f;color:var(--wellness)}.choice-panel{padding:18px}.home-screen .choice-panel{margin-top:0}.panel-head{gap:12px}.app-icon{position:relative;display:grid;place-items:center;width:56px;height:56px;flex:0 0 auto;overflow:hidden;border-radius:18px;background:#ffffffb8;box-shadow:0 16px 34px #6366f133}.app-icon img{display:block;width:100%;height:100%;object-fit:contain}.mood-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:9px;margin-top:18px}.mood-chip{min-height:64px;border:1px solid var(--line);border-radius:18px;background:#fff;color:var(--ink);text-align:left;padding:12px}.mood-chip strong,.mood-chip span{display:block}.mood-chip span{margin-top:3px;color:var(--muted);font-size:.82rem}.mood-chip.selected{border-color:transparent;background:linear-gradient(135deg,#6366f124,#5f927821);color:var(--indigo)}.range-field,.dropdown-field{display:flex;flex-direction:column;gap:8px}.range-field{margin-top:18px;color:var(--muted);font-size:.86rem}.range-field strong{color:var(--ink)}input[type=range]{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;height:6px;border-radius:999px;background:var(--line)}input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:22px;height:22px;border:3px solid #fff;border-radius:50%;background:var(--indigo);box-shadow:0 4px 12px #6366f159}.transport-field{display:grid;gap:10px;margin-top:18px}.field-title{display:flex;align-items:baseline;justify-content:space-between;gap:12px}.field-title span{color:var(--muted);font-size:.78rem;font-weight:850}.field-title small{color:#8d98a8;font-size:.72rem;font-weight:800;text-align:right}.transport-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.transport-chip{display:inline-flex;min-height:42px;align-items:center;justify-content:center;gap:7px;border:1px solid var(--line);border-radius:16px;background:#ffffffd1;color:var(--muted);padding:0 10px;font-size:.82rem;font-weight:850}.transport-chip .icon-glyph{width:18px;height:18px;stroke-width:2.25}.transport-chip .transport-icon-img{width:22px;height:22px}.transport-chip.selected{border-color:#6366f138;background:linear-gradient(135deg,#6366f121,#5f92781f);color:var(--indigo);box-shadow:inset 0 1px #ffffffdb}.select-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-top:18px}.dropdown-field>span{color:var(--muted);font-size:.78rem;font-weight:800}.calm-select{position:relative}.calm-select-trigger{position:relative;display:flex;width:100%;min-height:50px;align-items:center;justify-content:space-between;border:1px solid rgba(232,237,243,.94);border-radius:18px;background:linear-gradient(135deg,#fffffffa,#f6faf7e6),linear-gradient(90deg,rgba(99,102,241,.055),transparent 46%);box-shadow:inset 0 1px #ffffffe6;color:var(--ink);padding:0 46px 0 14px;text-align:left}.calm-select-trigger:after{position:absolute;right:17px;top:50%;width:8px;height:8px;border-bottom:2px solid currentColor;border-right:2px solid currentColor;color:var(--muted);content:"";pointer-events:none;transform:translateY(-65%) rotate(45deg)}.calm-select.open .calm-select-trigger{border-color:#6366f147;background:linear-gradient(135deg,#fffffffa,#ecebff7a),linear-gradient(90deg,rgba(95,146,120,.1),transparent 50%);box-shadow:inset 0 1px #ffffffeb,0 0 0 4px #6366f114}.calm-select.open .calm-select-trigger:after{transform:translateY(-35%) rotate(225deg)}.calm-select-trigger strong{color:var(--indigo);font-size:.96rem;font-weight:900;line-height:1.1}.calm-select-menu{position:absolute;left:0;right:0;top:calc(100% + 8px);z-index:35;display:grid;gap:6px;padding:8px;border:1px solid rgba(232,237,243,.94);border-radius:20px;background:#fffffff0;box-shadow:0 18px 38px #0f172a1f;-webkit-backdrop-filter:blur(18px) saturate(1.08);backdrop-filter:blur(18px) saturate(1.08)}.calm-select-option{display:flex;min-height:40px;align-items:center;justify-content:space-between;gap:12px;border:0;border-radius:14px;background:transparent;color:var(--muted);padding:0 10px;font-size:.86rem;font-weight:850;text-align:left}.calm-select-option.selected{background:linear-gradient(135deg,#6366f11f,#5f92781f);color:var(--indigo)}.calm-select-option i{display:grid;place-items:center;width:22px;height:22px;border-radius:50%;background:#6366f11f;font-size:.74rem;font-style:normal}.select-pop-enter-active,.select-pop-leave-active{transition:opacity .16s ease,transform .18s ease,filter .18s ease}.select-pop-enter-from,.select-pop-leave-to{opacity:0;filter:blur(4px);transform:translateY(-5px) scale(.98)}select,textarea{width:100%;border:1px solid var(--line);border-radius:16px;background:#fff;color:var(--ink)}select{min-height:42px;padding:0 12px}textarea{min-height:76px;padding:10px 12px;resize:vertical}.primary-action,.ghost-action{display:inline-flex;align-items:center;justify-content:center;min-height:46px;border-radius:999px;padding:0 18px;font-weight:800;text-decoration:none}.primary-action{width:100%;margin-top:20px;border:0;background:linear-gradient(135deg,var(--indigo),#a78bfa);color:#fff;box-shadow:var(--shadow-float)}.primary-action:disabled{opacity:.6;cursor:not-allowed}.ghost-action{border:1px solid var(--line);background:#fff;color:var(--muted)}.primary-action:active,.ghost-action:active,.icon-button:active,.back-button:active,.mood-chip:active,.calm-select-trigger:active,.calm-select-option:active,.place-main:active,.ambient-toggle:active,.feedback-chip:active,.backup-item:active{transform:scale(.98)}.ghost-action.compact{min-height:40px;padding:0 14px;white-space:nowrap}.location-field{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-top:18px;padding:14px;border:1px solid var(--line);border-radius:18px;background:#fff}.location-field div{display:flex;min-width:0;flex-direction:column;gap:5px}.location-field span{color:var(--muted);font-size:.78rem;font-weight:800}.location-field strong{overflow-wrap:anywhere;font-size:.98rem;line-height:1.2}.location-field small{color:var(--muted);font-size:.72rem;font-weight:750;line-height:1.35;opacity:.72}.favorite-start-switcher{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}.start-chip{min-height:34px;border:1px solid var(--line);border-radius:999px;background:#ffffffbd;color:var(--muted);padding:0 13px;font-size:.78rem;font-weight:850}.start-chip.selected{border-color:#6366f12e;background:var(--lavender);color:var(--indigo)}.ghost-action.saved{border-color:#5f927833;background:#5f92781f;color:var(--wellness)}.ghost-action.danger{color:var(--danger)}.result-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,300px),1fr));gap:12px;margin-top:18px}.place-card,.saved-card,.auth-panel,.profile-card,.profile-section,.admin-login-card,.admin-panel,.admin-stat,.detail-copy,.reason-list div,.empty-state{padding:16px}.place-main{width:100%;gap:12px;border:0;background:transparent;color:inherit;text-align:left}.place-main h2{line-height:1.22}.place-main p{line-height:1.45}.rank{display:grid;place-items:center;width:42px;height:42px;flex:0 0 auto;border-radius:50%;background:var(--mist);color:var(--wellness);font-size:.8rem;font-weight:900}.auth-screen{display:grid;min-height:calc(100vh - 48px);place-items:center;padding:42px 18px 118px}.auth-panel{width:min(420px,100%);display:grid;gap:16px;padding:26px;box-shadow:var(--shadow-calm);animation:auth-arrive .72s cubic-bezier(.2,.82,.2,1) both}.auth-brand{display:grid;justify-items:center;gap:6px;margin-bottom:2px}.auth-brand img{width:74px;height:74px;filter:drop-shadow(0 14px 32px rgba(99,102,241,.18))}.auth-brand strong{color:var(--ink);font-size:1.05rem;font-weight:950}.auth-brand span,.auth-form label span,.profile-card p,.profile-section p{color:var(--muted);font-size:.86rem;font-weight:750}.auth-form{display:grid;gap:12px}.auth-form h1{margin-bottom:2px;text-align:center}.auth-form label{display:grid;gap:6px}.auth-form input,.profile-name-field input,.favorite-start-form input{width:100%;min-height:48px;border:1px solid var(--line);border-radius:18px;background:#f8fafcdb;color:var(--ink);padding:0 14px;font:inherit;font-weight:800;outline:none}.auth-form input:focus,.profile-name-field input:focus,.favorite-start-form input:focus{border-color:#6366f16b;box-shadow:0 0 0 4px #6366f117}.link-action{border:0;background:transparent;color:var(--muted);font-weight:900}.auth-divider{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:10px;color:#9aa3b2;font-size:.78rem;font-weight:900}.auth-divider:before,.auth-divider:after{height:1px;background:var(--line);content:""}.google-slot{min-height:44px;display:grid;place-items:center}.google-fallback,.guest-link{justify-self:center}.profile-screen{max-width:980px;margin:0 auto}.profile-card{display:flex;align-items:center;gap:14px;margin-top:18px;box-shadow:var(--shadow-calm)}.profile-avatar-wrap{flex:0 0 auto}.profile-avatar{width:74px;height:74px;border-radius:24px;object-fit:cover}.profile-avatar.fallback{display:grid;place-items:center;background:var(--mist);color:var(--wellness);font-size:1.5rem;font-weight:950}.profile-identity{min-width:0;display:grid;flex:1;gap:10px}.profile-name-field{display:grid;gap:6px}.profile-name-field span{color:var(--muted);font-size:.78rem;font-weight:850}.profile-actions{display:flex;flex-wrap:wrap;gap:8px}.avatar-upload{position:relative;overflow:hidden}.avatar-upload input{position:absolute;top:0;right:0;bottom:0;left:0;opacity:0}.primary-action.compact{min-height:42px;padding:0 18px}.edit-profile-button{justify-self:start;min-height:36px;padding:0 14px}.profile-grid{display:grid;grid-template-columns:minmax(240px,.8fr) minmax(320px,1.2fr);gap:14px;margin-top:14px}.profile-section{display:grid;gap:12px;align-content:start;box-shadow:var(--shadow-calm)}.saved-start-list{display:grid;gap:8px}.saved-start-item{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px;border-radius:16px;background:#f1f5f9d1}.saved-start-item div{min-width:0;display:grid;gap:3px}.saved-start-item b{color:var(--ink);font-size:.9rem}.saved-start-item span{color:var(--muted);font-size:.74rem;font-weight:750}.favorite-start-form{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:8px}.preference-panel{grid-row:span 2}.preference-slider{display:grid;gap:8px}.preference-slider span{display:flex;justify-content:space-between;color:var(--muted);font-size:.84rem;font-weight:850}.danger-zone{border:1px solid rgba(196,69,69,.1)}.admin-screen{max-width:1040px;margin:0 auto}.admin-login-card{width:min(460px,100%);display:grid;gap:12px;margin:28px auto 0;box-shadow:var(--shadow-calm)}.admin-login-form{display:grid;gap:10px}.admin-login-form input{width:100%;min-height:48px;border:1px solid var(--line);border-radius:18px;background:#f8fafcdb;color:var(--ink);padding:0 14px;font:inherit;font-weight:800;outline:none}.admin-tabs{display:flex;flex-wrap:wrap;gap:8px;margin-top:18px}.admin-tabs button{min-height:38px;border:1px solid var(--line);border-radius:999px;background:#ffffffd1;color:var(--muted);padding:0 14px;font-weight:850}.admin-tabs button.active{border-color:#6366f133;background:var(--lavender);color:var(--indigo)}.admin-tabs .admin-logout-button{margin-left:auto;border-color:#b44a423d;background:#b44a4214;color:var(--danger)}.admin-grid{display:grid;grid-template-columns:repeat(5,minmax(120px,1fr));gap:12px;margin-top:16px}.admin-stat{display:grid;gap:8px;box-shadow:var(--shadow-calm)}.admin-stat span,.admin-row span,.admin-row small,.admin-panel p{color:var(--muted);font-size:.78rem;font-weight:750}.admin-stat strong{font-size:1.8rem}.admin-panel{display:grid;gap:12px;margin-top:16px;box-shadow:var(--shadow-calm)}.admin-panel.wide{grid-column:1 / -1}.admin-panel-head,.admin-row{display:flex;align-items:center;justify-content:space-between;gap:12px}.admin-table{display:grid;gap:8px}.admin-row{padding:10px 0;border-top:1px solid rgba(232,237,243,.76)}.admin-row div{min-width:0;display:grid;gap:3px}.admin-row b,.admin-row span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.admin-category-list{display:flex;flex-wrap:wrap;gap:8px}.admin-category-list span{border-radius:999px;background:#f1f5f9;color:var(--muted);padding:6px 10px;font-size:.78rem;font-weight:850}.reason{padding-left:12px;border-left:3px solid rgba(99,102,241,.16)}.card-footer,.action-row{margin-top:12px}.detail-map-card{position:relative;display:flex;min-height:520px;flex-direction:column;gap:10px;margin-top:20px;padding:12px;overflow:hidden}.mapbox-route{width:100%;min-height:0;flex:1 1 auto;border-radius:20px;overflow:hidden;background:linear-gradient(135deg,#e5f3eaf2,#ffffffe6 48%,#ecebfff2),linear-gradient(90deg,rgba(17,24,39,.05) 1px,transparent 1px),linear-gradient(0deg,rgba(17,24,39,.05) 1px,transparent 1px);background-size:auto,26px 26px,26px 26px}.map-route-status{position:static;display:flex;align-items:center;gap:8px;flex-wrap:wrap;padding:12px 14px;border-radius:18px;background:#ffffffeb;box-shadow:var(--shadow-calm);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.map-route-status>strong,.map-route-status .commute-inline strong{color:var(--indigo)}.map-route-status>span,.map-route-status small{color:var(--muted);font-weight:800}.map-route-status small{width:100%;font-size:.72rem;line-height:1.55}.map-route-status:has(.commute-inline .transport-icon-img){border:1px solid rgba(226,232,240,.72)}.commute-inline{display:inline-flex;align-items:center;gap:8px;min-width:0}.commute-inline .icon-glyph{color:var(--indigo)}.commute-inline .transport-icon-img{width:24px;height:24px}.commute-chip.unavailable,.route-option-chip.unavailable{background:#6973861a;color:#697386}.route-marker{display:grid;place-items:center;width:34px;height:34px;border:3px solid #fff;border-radius:50% 50% 50% 12%;background:var(--indigo);color:#fff;box-shadow:0 10px 24px #0f172a38;transform:rotate(-45deg)}.route-marker span{display:block;font-size:.78rem;font-weight:900;transform:rotate(45deg)}.route-marker.destination{background:var(--wellness)}.detail-sidebar{display:flex;flex-direction:column;gap:14px}.detail-sidebar .detail-copy,.detail-sidebar .reason-list,.detail-sidebar .action-row{margin-top:0}.detail-copy{display:flex;flex-direction:column;gap:16px}.description-block{position:relative;overflow:hidden;transition:max-height .24s ease}.description-block.collapsed{max-height:168px}.description-block.collapsed:after{position:absolute;right:0;bottom:0;left:0;height:52px;background:linear-gradient(180deg,#fff0,#fffffff5);content:"";pointer-events:none}.description-toggle{align-self:flex-start;min-height:34px;border:1px solid var(--line);border-radius:999px;background:#ffffffc7;color:var(--muted);padding:0 12px;font-size:.78rem;font-weight:850}.detail-info-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.detail-info-grid>span{display:flex;min-width:0;min-height:64px;flex-direction:column;justify-content:center;gap:4px;padding:12px;border-radius:18px;background:#f1f5f9}.detail-info-grid>.info-chip{align-items:flex-start}.detail-info-grid>.info-chip .icon-glyph{margin-bottom:2px;font-size:1.05rem}.detail-info-grid strong{overflow-wrap:anywhere;color:var(--ink);line-height:1.25}.detail-info-grid small{color:var(--muted);font-size:.72rem;font-weight:800;line-height:1.25}.weather-chip-grid{display:flex;flex-wrap:wrap;gap:8px}.weather-chip{display:inline-flex;align-items:center;min-height:34px;gap:7px;padding:7px 10px;border-radius:999px;color:var(--muted);font-size:.8rem;font-weight:850;line-height:1}.weather-chip strong{color:inherit;line-height:1}.weather-chip small{color:inherit;font-size:.72rem;font-weight:800;opacity:.78}.weather-condition{background:#5f927821;color:var(--wellness)}.weather-rain{background:#6366f11c;color:var(--indigo)}.weather-wind{background:#6973861f;color:#5d6979}.weather-temp{background:#d49a3a21;color:var(--amber)}.weather-temp.temp-cold{background:#3d78b821;color:#3d78b8}.weather-temp.temp-mild{background:#5f927821;color:var(--wellness)}.weather-temp.temp-warm{background:#d49a3a26;color:var(--amber)}.weather-temp.temp-hot{background:#b44a4221;color:var(--danger)}.aqi-chip,.aqi-good{background:#5f927821;color:var(--wellness)}.aqi-moderate{background:#d49a3a21;color:var(--amber)}.aqi-sensitive{background:#d6803621;color:#c66f2f}.aqi-unhealthy{background:#b44a4221;color:var(--danger)}.aqi-very-unhealthy{background:#8453b021;color:#8453b0}.aqi-hazardous{background:#6d284221;color:#7d314f}.aqi-unknown{background:#6973861f;color:#5d6979}.badge-row>.weather-condition{background:#5f927821;color:var(--wellness)}.badge-row>.weather-rain{background:#6366f11c;color:var(--indigo)}.badge-row>.weather-wind{background:#6973861f;color:#5d6979}.badge-row>.weather-temp{background:#d49a3a21;color:var(--amber)}.badge-row>.weather-temp.temp-cold{background:#3d78b821;color:#3d78b8}.badge-row>.weather-temp.temp-mild{background:#5f927821;color:var(--wellness)}.badge-row>.weather-temp.temp-warm{background:#d49a3a26;color:var(--amber)}.badge-row>.weather-temp.temp-hot{background:#b44a4221;color:var(--danger)}.badge-row>.aqi-chip,.badge-row>.aqi-good{background:#5f927821;color:var(--wellness)}.badge-row>.aqi-moderate{background:#d49a3a21;color:var(--amber)}.badge-row>.aqi-sensitive{background:#d6803621;color:#c66f2f}.badge-row>.aqi-unhealthy{background:#b44a4221;color:var(--danger)}.badge-row>.aqi-very-unhealthy{background:#8453b021;color:#8453b0}.badge-row>.aqi-hazardous{background:#6d284221;color:#7d314f}.badge-row>.aqi-unknown{background:#6973861f;color:#5d6979}.feedback-row{display:flex;flex-wrap:wrap;gap:7px;margin-top:12px}.feedback-chip{min-height:30px;border:1px solid var(--line);border-radius:999px;background:#ffffffb8;color:var(--muted);padding:5px 10px;font-size:.75rem;font-weight:800}.feedback-chip.selected{border-color:transparent;background:#6366f11f;color:var(--indigo)}.reason-list{display:flex;flex-direction:column;gap:10px}.reason-list div{display:flex;flex-direction:column;gap:5px}.reason-list span{color:var(--muted);line-height:1.45}.route-subhint{display:block;margin-top:4px;color:#8d98a8;font-size:.78rem;font-weight:800;line-height:1.35}.route-option-list{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}.route-option-chip{display:inline-grid;grid-template-columns:auto auto;grid-template-rows:auto auto;align-items:center;column-gap:7px;row-gap:1px;min-height:42px;padding:8px 10px;border:1px solid rgba(226,232,240,.86);border-radius:15px;background:#f8fafcd6;color:var(--muted)}.route-option-chip.selected{border-color:#6366f142;background:#6366f117;color:var(--indigo)}.route-option-chip .transport-icon-img{grid-row:1 / 3;width:22px;height:22px}.route-option-chip strong{color:inherit;font-size:.78rem;line-height:1.05}.route-option-chip small{color:inherit;font-size:.7rem;font-weight:900;opacity:.78}.backup-list{display:grid;gap:9px;margin-top:0;padding:16px;border-radius:26px;background:#ffffffeb;box-shadow:var(--shadow-calm)}.backup-list>strong{color:var(--ink)}.backup-list p{margin:0;color:var(--muted);font-size:.88rem;line-height:1.5}.backup-item{display:flex;align-items:center;justify-content:space-between;gap:12px;min-height:42px;border:1px solid var(--line);border-radius:16px;background:#fff;color:var(--ink);padding:9px 11px;text-align:left}.backup-item span{overflow-wrap:anywhere;font-weight:850}.backup-item small{flex:0 0 auto;color:var(--muted);font-weight:800}.action-row{gap:10px}.action-row .primary-action,.action-row .ghost-action{gap:8px}.action-row .primary-action{flex:1 1 auto;min-width:0;margin-top:0}.detail-sidebar .ghost-action{min-width:116px}.map-action{flex:0 0 auto;min-width:142px;white-space:nowrap}.map-action span{white-space:nowrap}.saved-card h2{margin-bottom:4px}.empty-state{margin-top:34px;text-align:center}.empty-secondary{width:100%;margin-top:10px}.loading-state{position:relative;display:grid;place-items:center;min-height:430px;margin-top:34px;padding:32px 28px;border-radius:26px;background:#ffffffeb;box-shadow:var(--shadow-calm);text-align:center}.loading-visual{position:relative;width:min(420px,100%);min-height:156px;margin-bottom:18px}.loader-calm{position:relative;z-index:3;width:96px;height:96px;margin:0 auto 18px;border-radius:50%;background:radial-gradient(circle at 50% 52%,rgba(99,102,241,.12),transparent 31%),radial-gradient(circle at 58% 38%,rgba(95,146,120,.12),transparent 18%);box-shadow:0 18px 42px #6366f11f;animation:calm-breathe 3.8s ease-in-out infinite}.route-preview{position:absolute;left:10%;right:10%;top:50px;height:74px;opacity:.86}.route-thread{position:absolute;left:5%;right:5%;top:35px;height:8px;border-radius:999px;background:linear-gradient(90deg,#5f92781f,#5f92786b,#6366f142),repeating-linear-gradient(90deg,transparent 0 14px,rgba(255,255,255,.68) 14px 20px);transform:rotate(-7deg);animation:route-glide 3.6s ease-in-out infinite}.node{position:absolute;display:block;width:13px;height:13px;border:3px solid #fff;border-radius:50%;box-shadow:0 10px 24px #0f172a24}.node.start{left:13%;top:38px;background:var(--indigo);animation:node-breathe 2.8s ease-in-out infinite}.node.mid{left:50%;top:25px;background:var(--amber);animation:node-breathe 2.8s ease-in-out .45s infinite}.node.end{right:12%;top:16px;background:var(--wellness);animation:node-breathe 2.8s ease-in-out .9s infinite}.loading-card-stack{position:absolute;left:50%;bottom:0;z-index:2;display:grid;width:min(290px,86%);gap:7px;transform:translate(-50%)}.loading-card-stack span{height:14px;border-radius:999px;background:linear-gradient(90deg,#f1f5f966,#e5f3eadb,#f1f5f966);background-size:220% 100%;animation:skeleton-flow 2.8s ease-in-out infinite}.loading-card-stack span:nth-child(2){width:78%;animation-delay:.2s}.loading-card-stack span:nth-child(3){width:56%;animation-delay:.4s}.calm-ring,.calm-dot,.calm-path{position:absolute;display:block}.calm-ring{top:16px;right:16px;bottom:16px;left:16px;border:1px solid rgba(99,102,241,.18);border-radius:50%}.calm-ring.one{animation:calm-pulse 3.2s ease-in-out infinite}.calm-ring.two{top:26px;right:26px;bottom:26px;left:26px;border-color:#5f927829;animation:calm-pulse 3.2s ease-in-out .8s infinite}.calm-dot{border-radius:50%}.calm-dot.main{left:38px;top:39px;width:20px;height:20px;background:var(--indigo);box-shadow:0 14px 28px #6366f13d}.calm-dot.drift{right:24px;top:24px;width:12px;height:12px;background:var(--wellness);animation:calm-drift 4.6s ease-in-out infinite}.calm-path{left:22px;right:22px;bottom:24px;height:2px;border-radius:999px;background:linear-gradient(90deg,transparent,rgba(95,146,120,.35),transparent);transform-origin:center;animation:calm-route 3.8s ease-in-out infinite}.loading-state p{max-width:520px}.loading-steps{display:flex;flex-wrap:wrap;justify-content:center;gap:8px;margin-top:18px}.loading-steps span{display:inline-flex;align-items:center;min-height:30px;padding:6px 10px;border-radius:999px;background:#f1f5f9;color:var(--muted);font-size:.78rem;font-weight:800}.error-state{text-align:left}.error-state h2,.error-state p{text-align:center}.error-state pre{overflow:auto;max-height:220px;margin:14px 0 0;padding:12px;border:1px solid rgba(180,74,66,.18);border-radius:16px;background:#b44a4212;color:var(--danger);white-space:pre-wrap;word-break:break-word}@keyframes calm-breathe{0%,to{transform:scale(.98);opacity:.9}50%{transform:scale(1.04);opacity:1}}@keyframes calm-pulse{0%,to{transform:scale(.94);opacity:.35}50%{transform:scale(1.08);opacity:.78}}@keyframes calm-drift{0%,to{transform:translateZ(0)}45%{transform:translate3d(-9px,8px,0)}70%{transform:translate3d(-3px,12px,0)}}@keyframes calm-route{0%,to{opacity:.32;transform:translateY(0) scaleX(.72)}50%{opacity:.8;transform:translateY(-4px) scaleX(1)}}@keyframes route-glide{0%,to{transform:rotate(-7deg) translate(-4px);opacity:.56}50%{transform:rotate(-7deg) translate(5px);opacity:1}}@keyframes node-breathe{0%,to{transform:scale(.92);opacity:.62}50%{transform:scale(1.12);opacity:1}}@keyframes skeleton-flow{0%,to{background-position:0% 50%;opacity:.55}50%{background-position:100% 50%;opacity:1}}@keyframes auth-arrive{0%{opacity:0;transform:translateY(18px) scale(.985)}to{opacity:1;transform:translateY(0) scale(1)}}.bottom-nav{position:fixed;left:50%;bottom:18px;z-index:110;width:min(560px,calc(100vw - 32px));display:flex;justify-content:space-around;border-radius:28px;background:#ffffffeb;padding:10px 12px;box-shadow:var(--shadow-calm);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);transform:translate(-50%)}.bottom-nav button{position:relative;min-width:64px;border:0;background:transparent;color:#9aa3b2;font-weight:800}.bottom-nav button.active{color:var(--indigo)}.nav-icon{display:block;font-size:1.18rem;line-height:1}.nav-avatar{width:24px;height:24px;display:grid;place-items:center;margin:0 auto;overflow:hidden;border:1px solid rgba(99,102,241,.18);border-radius:50%;background:var(--mist);color:var(--wellness);font-size:.78rem;font-weight:950}.nav-avatar img{width:100%;height:100%;object-fit:cover}.bottom-nav button span:last-child{display:block;margin-top:4px;font-size:.68rem}.bottom-nav i{right:8px;top:-3px}.toast{position:fixed;left:50%;bottom:94px;z-index:30;width:max-content;max-width:calc(100% - 48px);padding:10px 14px;border-radius:999px;background:var(--ink);color:#fff;opacity:0;pointer-events:none;transform:translate(-50%) translateY(10px);transition:opacity .18s ease,transform .18s ease}.toast.show{opacity:1;transform:translate(-50%) translateY(0)}@media(hover:hover){.place-card:hover,.saved-card:hover,.detail-copy:hover,.reason-list div:hover,.backup-list:hover,.choice-panel:hover{box-shadow:0 18px 44px #0f172a1f;transform:translateY(-2px)}.primary-action:hover,.ghost-action:hover,.icon-button:hover,.back-button:hover,.ambient-toggle:hover,.calm-select-trigger:hover,.transport-chip:hover,.feedback-chip:hover,.backup-item:hover{box-shadow:0 14px 32px #0f172a1a;transform:translateY(-1px)}.calm-select-option:hover{background:#f1f5f9db;color:var(--ink)}.ambient-toggle:hover span{max-width:80px;opacity:1}.mood-chip:hover{border-color:#6366f140;box-shadow:0 12px 28px #0f172a14;transform:translateY(-1px)}}button:focus-visible,a:focus-visible,select:focus-visible,textarea:focus-visible,input:focus-visible{outline:3px solid rgba(99,102,241,.18);outline-offset:3px}@keyframes ambient-wash{0%{opacity:.72;transform:translate3d(-1.5%,-1%,0) scale(1)}to{opacity:1;transform:translate3d(1.5%,1%,0) scale(1.04)}}@keyframes startup-breathe{0%,to{transform:translateY(0) scale(1)}50%{transform:translateY(-4px) scale(1.035)}}@keyframes startup-settle{0%,58%{transform:translateY(0) scale(1)}to{transform:translateY(-36px) scale(.72)}}@keyframes startup-settle-copy{0%,58%{transform:translateY(0) scale(1);opacity:1}to{transform:translateY(-42px) scale(.9);opacity:.9}}@keyframes startup-ring{0%,to{opacity:.28;transform:scale(.92)}50%{opacity:.82;transform:scale(1.08)}}@keyframes startup-line{0%,to{opacity:.4;transform:rotate(-10deg) translate(-8px)}50%{opacity:.86;transform:rotate(-10deg) translate(8px)}}@keyframes startup-node{0%,to{transform:scale(.88)}50%{transform:scale(1.16)}}@keyframes startup-route-drift{0%{opacity:.32;transform:translate3d(-2%,0,0) rotate(-6deg)}to{opacity:.72;transform:translate3d(2%,-8px,0) rotate(-6deg)}}@media(min-width:900px){.detail-screen{display:grid;grid-template-columns:minmax(430px,1fr) minmax(330px,.78fr);gap:18px;align-content:start;max-width:1040px;margin:0 auto}.detail-screen .screen-header{grid-column:1 / -1}.detail-map-card{margin-top:0;min-height:min(680px,calc(100vh - 188px))}.mapbox-route{min-height:0}.detail-sidebar{align-self:start}}@media(max-width:760px){.ambient-toggle{left:16px;bottom:88px}.app-shell{padding:0}.app-surface{min-height:100vh;border:0;border-radius:0}.screen{min-height:100vh;padding:28px 16px 130px}.back-button{left:16px;top:max(20px,calc(env(safe-area-inset-top) + 24px))}.journey-grid{top:8%;right:-20%;bottom:12%;left:-20%;opacity:.2;background-size:52px 52px}.journey-route.one{left:-22%;right:24%;bottom:19%;opacity:.24}.journey-route.two{left:42%;right:-32%;top:40%;opacity:.16}.journey-ticket{left:-18px;top:16%;width:96px;height:58px;opacity:.24}.journey-compass{right:-48px;bottom:16%;width:132px;height:132px;opacity:.32}.ambient-toggle{left:16px;bottom:84px;min-height:34px;padding:0 10px}.ambient-toggle span{display:none}.home-screen{display:block}.home-screen .next-card,.home-screen .choice-panel{margin-top:18px}.select-grid{grid-template-columns:1fr}.calm-select-menu{position:relative;top:auto;margin-top:8px;box-shadow:0 12px 28px #0f172a14}.dropdown-field{min-height:0}.home-screen .choice-panel{margin-bottom:44px}.auth-screen{min-height:100vh;padding:30px 16px 136px}.auth-panel{padding:22px}.profile-grid{grid-template-columns:1fr}.admin-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.admin-row{display:grid;align-items:stretch}.favorite-start-form,.saved-start-item{display:grid;grid-template-columns:1fr}.saved-start-item{align-items:stretch}.transport-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.detail-screen{padding-bottom:164px}.detail-info-grid{grid-template-columns:1fr}.detail-map-card{min-height:auto;margin-bottom:16px;overflow:visible}.mapbox-route{min-height:min(360px,54vh)}.map-route-status{position:relative;z-index:2;margin-top:2px}}@media(max-width:430px){h1{font-size:1.78rem}.location-field{align-items:stretch;flex-direction:column}.ghost-action.compact{width:100%}.bottom-nav{bottom:12px;width:calc(100vw - 24px)}}@media(prefers-reduced-motion:reduce){*{animation:none!important;scroll-behavior:auto!important;transition:none!important}}
