:root{color-scheme:light;font-family:Sora,Avenir Next,Segoe UI,sans-serif;line-height:1.45;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{color:#0f172a;background:#f8fafc;overflow-x:hidden}h1,h2,h3,p{margin:0}button,input,select{font:inherit}button{cursor:pointer}a{color:inherit}:root{--workspace-bg: #f6f1e8;--surface: #ffffff;--surface-alt: #fcf8f2;--border: #e7dac9;--text: #2f2419;--muted: #7a6856;--accent: #b45e2f;--accent-bg: #f9e8d7;--danger: #b8472f;--danger-bg: #fdeee8;--focus-ring: #b45e2f}.planner-workspace-shell{height:100vh;display:grid;grid-template-rows:56px minmax(0,1fr);background:var(--workspace-bg)}.planner-header{position:relative;z-index:120;display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:0 .9rem;background:#fff;border-bottom:1px solid var(--border)}.planner-branding{display:flex;align-items:center;gap:.55rem;min-width:0}.planner-brand-logo{height:34px;width:auto;max-width:min(20vw,132px);object-fit:contain;display:block}.planner-brand-copy{min-width:0;display:grid;gap:.02rem}.planner-brand-title{font-size:.88rem;font-weight:760;letter-spacing:.015em;line-height:1.05;color:#8f6b4a;white-space:nowrap}.planner-brand-subtitle{font-size:.7rem;font-weight:620;letter-spacing:.08em;text-transform:uppercase;color:#a18364;white-space:nowrap}.planner-header-actions{position:relative;z-index:125}.planner-login-button,.planner-avatar-button{display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--border);background:#fff;color:var(--text)}.planner-login-button{min-height:32px;padding:0 .8rem;border-radius:8px;text-decoration:none;font-size:.82rem;font-weight:600}.planner-avatar-button{width:32px;height:32px;border-radius:999px;font-size:.78rem;font-weight:700}.planner-avatar-menu{position:absolute;top:calc(100% + .35rem);right:0;min-width:156px;border:1px solid var(--border);border-radius:10px;background:#fff;box-shadow:0 14px 36px #0f172a26;overflow:hidden;z-index:130}.planner-menu-item{width:100%;display:block;text-decoration:none;text-align:left;border:0;background:#fff;color:var(--text);padding:.55rem .72rem;font-size:.82rem}.planner-menu-item:hover{background:#f8eee1}.planner-menu-item:focus-visible{outline:2px solid var(--focus-ring);outline-offset:-2px}.planner-body{min-height:0;display:grid;grid-template-columns:64px 360px minmax(0,1fr)}.planner-mini-sidebar{min-height:0;display:grid;grid-template-rows:auto minmax(0,1fr);justify-items:center;gap:.75rem;padding:.6rem .35rem;background:#f2eadf;border-right:1px solid var(--border)}.mini-sidebar-top{display:grid;gap:.5rem}.mini-route-style-toggle{display:grid;gap:.3rem;margin-top:.1rem}.mini-route-style-button{min-height:26px;border:1px solid #dcc8b1;border-radius:7px;background:#fff;color:#5a4530;font-size:.68rem;font-weight:700;line-height:1;padding:.2rem .34rem}.mini-route-style-button.active{border-color:#ce8e5f;background:var(--accent-bg);color:#8d4e23}.mini-sidebar-bottom{align-self:end;display:grid;justify-items:center;gap:.45rem;width:100%;padding:0 .1rem}.mini-icon-button{width:44px;min-height:44px;border-radius:10px}.planner-sidebar{min-height:0;overflow-y:auto;overflow-x:hidden;background:var(--surface);border-right:1px solid var(--border);padding:.3rem 0}.planner-section-card{display:grid;gap:.56rem;padding:.68rem .8rem;border-bottom:1px solid #efe4d7}.section-header{display:flex;align-items:center;justify-content:space-between}.planner-section-card h2{font-size:.8rem;font-weight:650;letter-spacing:.04em;text-transform:uppercase;color:#523d2b}.current-route-card{border:1px solid var(--border);border-radius:12px;background:linear-gradient(180deg,#fffdf9,#fcf6ef);padding:.64rem .64rem .56rem;display:grid;gap:.22rem}.current-route-head{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.current-route-name{font-size:.94rem;font-weight:760;color:#4d3a2a;line-height:1.2}.current-route-badge{display:inline-flex;align-items:center;min-height:22px;border-radius:999px;border:1px solid #e1c3a4;background:#f9e8d7;color:#8d4e23;font-size:.66rem;font-weight:750;letter-spacing:.06em;text-transform:uppercase;padding:0 .48rem;white-space:nowrap}.current-route-subtitle{color:var(--muted);font-size:.74rem}.current-route-actions{margin-top:.34rem;display:grid;grid-template-columns:1fr 1fr;gap:.42rem}.current-route-change-button,.current-route-create-button{min-height:36px;border-radius:10px;font-size:.79rem;font-weight:700;line-height:1;padding:.45rem .55rem}.current-route-change-button{border:1px solid #dcc4ab;background:#fffaf3;color:#7b5838}.current-route-create-button{border:1px solid #d08f60;background:#f9e8d7;color:#8d4e23;display:inline-flex;align-items:center;justify-content:center;gap:.24rem}.current-route-create-icon{width:15px;height:15px}.current-route-actions-secondary{margin-top:.22rem;grid-template-columns:1fr}.current-route-delete-button{min-height:32px;border:1px dashed #e8bdb1;border-radius:10px;background:#fff5f2;color:#ab3f2c;font-size:.75rem;font-weight:740;padding:.3rem .52rem}.current-route-delete-button:hover{background:#fdece6}.route-explorer-close{min-width:30px;min-height:30px;border-radius:8px;border:1px solid #dec8b0;background:#fffaf3;color:#8d4e23;display:inline-flex;align-items:center;justify-content:center}.route-explorer-grid{display:grid;grid-template-columns:1fr 1fr;gap:.45rem}.route-explorer-preset-button{min-height:36px;border-radius:9px;border:1px solid #dec8b0;background:#fffaf3;color:#5b4632;display:inline-flex;align-items:center;justify-content:flex-start;gap:.36rem;padding:.35rem .45rem;font-size:.74rem;font-weight:700}.route-explorer-preset-button:disabled{opacity:.65;cursor:not-allowed}.route-explorer-preset-icon{width:16px;height:16px}.route-explorer-actions{display:grid;grid-template-columns:1fr 1fr;gap:.4rem;margin-bottom:.35rem}.marker-tool-card{border:1px solid var(--border);border-radius:10px;margin:.2rem .8rem .8rem;padding:.72rem;background:#fdf8f2;gap:.72rem}.marker-title-label{display:grid;gap:.34rem;font-size:.74rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:#5c4633}.marker-title-input{width:100%;min-height:38px;border:1px solid #dac4ae;border-radius:10px;background:#fff;color:#2f2419;font-size:.84rem;padding:.52rem .62rem}.marker-color-picker{display:grid;gap:.4rem}.marker-color-picker p{margin:0;font-size:.74rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:#5c4633}.marker-color-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:.42rem}.marker-color-swatch{width:100%;min-height:34px;border:2px solid rgba(255,255,255,.9);border-radius:8px;box-shadow:0 0 0 1px #6d4a3138}.marker-color-swatch.selected{box-shadow:0 0 0 2px #b45e2f73,0 8px 16px #3f2a1b3d;transform:translateY(-1px)}.marker-tool-status{border:1px dashed #dcc7b2;border-radius:9px;background:#fffaf3;padding:.5rem .58rem;display:grid;gap:.18rem}.marker-tool-status small{font-size:.71rem;color:#7a6856}.subtle-status.marker-armed{color:#8d4e23;font-weight:620}.route-ai-card{border:1px solid var(--border);border-radius:8px;background:var(--surface-alt);padding:.52rem .58rem;display:grid;gap:.5rem}.route-ai-actions{display:grid;grid-template-columns:1fr 1fr;gap:.42rem}.route-ai-open-button,.route-ai-clear-button{min-height:32px;border-radius:8px;font-size:.74rem;font-weight:700;line-height:1;padding:.35rem .5rem}.route-ai-open-button{border:1px solid #d08f60;background:#f9e8d7;color:#8d4e23;display:inline-flex;align-items:center;justify-content:center;gap:.24rem}.route-ai-open-icon{width:14px;height:14px}.route-ai-clear-button{border:1px solid #dec8b0;background:#fffaf3;color:#7b5838}.route-ai-open-button:disabled,.route-ai-clear-button:disabled{opacity:.6;cursor:not-allowed}.route-ai-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#1818186b;display:grid;place-items:center;z-index:180;padding:1rem}.route-ai-dialog{width:min(760px,94vw);max-height:min(78vh,700px);border:1px solid #e5d4c4;border-radius:14px;background:#fffdfb;box-shadow:0 24px 58px #3a2a1d47;padding:.8rem;display:grid;grid-template-rows:auto minmax(0,1fr) auto;gap:.58rem}.route-ai-header{display:flex;justify-content:space-between;gap:1rem;align-items:flex-start}.route-ai-header h3{font-size:1rem;color:#4c3725}.route-ai-header p{font-size:.76rem;color:#7a6856;margin-top:.14rem}.route-ai-close{min-width:32px;min-height:32px;border-radius:8px;border:1px solid #dec8b0;background:#fffaf3;color:#8d4e23;display:inline-flex;align-items:center;justify-content:center}.route-ai-messages{min-height:0;overflow-y:auto;border:1px solid #ebdfd2;border-radius:10px;background:#fff;padding:.58rem;display:grid;gap:.42rem}.route-ai-message{border-radius:10px;border:1px solid #e8dbc9;padding:.42rem .5rem;display:grid;gap:.22rem}.route-ai-message.assistant{background:#fff7ee}.route-ai-message.user{background:#f7f1e8}.route-ai-message strong{font-size:.7rem;text-transform:uppercase;letter-spacing:.05em;color:#7b5838}.route-ai-message p{font-size:.81rem;color:#3e2d1f;line-height:1.35}.route-ai-input-row{display:grid;grid-template-columns:1fr auto;gap:.46rem}.route-ai-input-row input{width:100%;min-height:38px;border:1px solid #dec8b0;border-radius:10px;padding:.46rem .6rem;font-size:.84rem;color:#2f2419}.route-ai-input-row button{min-width:40px;min-height:38px;border:1px solid #b45e2f;border-radius:10px;background:linear-gradient(180deg,#c86b36,#b45e2f);color:#fff;display:inline-flex;align-items:center;justify-content:center}.route-ai-input-row button:disabled{opacity:.6;cursor:not-allowed}.itinerary-form-card{border:1px solid var(--border);border-radius:10px;margin:.2rem .8rem .8rem;padding:.72rem;background:#fdf8f2}.itinerary-form-grid{display:grid;gap:.56rem}.itinerary-form-grid label{display:grid;gap:.22rem;font-size:.74rem;font-weight:680;letter-spacing:.04em;text-transform:uppercase;color:#5b4633}.itinerary-form-grid input,.itinerary-form-grid select,.itinerary-form-grid textarea{width:100%;min-height:36px;border:1px solid #dcc8b1;border-radius:9px;background:#fff;color:var(--text);font-size:.82rem;padding:.42rem .55rem}.itinerary-form-grid textarea{min-height:80px;resize:vertical}.itinerary-inline-grid{display:grid;grid-template-columns:1fr 1fr;gap:.46rem}.itinerary-inline-grid-three{grid-template-columns:repeat(3,minmax(0,1fr))}.itinerary-toggle-row{display:flex;align-items:center;flex-wrap:wrap;gap:.8rem}.itinerary-toggle-row label{display:inline-flex;align-items:center;gap:.28rem;font-size:.74rem;font-weight:620;text-transform:none;letter-spacing:normal}.itinerary-toggle-row input[type=checkbox]{width:14px;min-height:14px}.itinerary-generate-button{min-height:36px;border:1px solid #d08f60;border-radius:10px;background:#f9e8d7;color:#8d4e23;display:inline-flex;align-items:center;justify-content:center;gap:.28rem;font-size:.8rem;font-weight:700}.itinerary-generate-button:disabled{opacity:.6;cursor:not-allowed}.itinerary-result-card{gap:.52rem}.itinerary-summary{font-size:.79rem;line-height:1.4;color:#4b3725}.itinerary-diagnostics{border:1px solid #e6d6c4;border-radius:8px;background:#fffaf4;padding:.45rem .52rem;display:grid;gap:.2rem}.itinerary-diagnostics small{font-size:.72rem;color:#6f5841;line-height:1.35}.itinerary-days-card{gap:.38rem}.itinerary-day-row{border:1px solid var(--border);border-radius:9px;background:#fcf7ef;padding:.46rem .5rem;display:grid;gap:.08rem}.itinerary-day-title{font-size:.78rem;font-weight:730;color:#4d3928}.itinerary-day-row small{font-size:.72rem;color:#745b44;line-height:1.3}.overview-metrics{display:grid;gap:.45rem}.overview-metrics article{background:var(--surface-alt);border:1px solid var(--border);border-radius:8px;padding:.5rem .55rem}.metric-label{font-size:.72rem;color:var(--muted)}.metric-value{margin-top:.12rem;font-size:.9rem;font-weight:700}.subtle-status{font-size:.72rem;color:var(--muted);line-height:1.35}.subtle-status-error{color:#ab3f2c}.planner-toolbar{display:grid;grid-template-columns:repeat(5,1fr);gap:.38rem}.icon-button{min-height:32px;border:1px solid var(--border);border-radius:8px;background:#fff;color:#5a4530;font-size:.9rem;display:inline-flex;align-items:center;justify-content:center;transition:background-color .14s ease,border-color .14s ease,color .14s ease}.control-icon{width:14px;height:14px;object-fit:contain;display:block}.icon-button:hover:not(:disabled){background:#f8eee1}.icon-button.active{border-color:#ce8e5f;background:var(--accent-bg);color:#8d4e23}.icon-button.stale{border-color:#d9a85f;background:#fff5dc;color:#9a5a20}.icon-button:disabled{opacity:.45;cursor:not-allowed}.icon-button.danger{border-color:#f4c8c2;background:var(--danger-bg);color:var(--danger)}.map-type-segmented{display:grid;grid-template-columns:repeat(4,1fr);gap:.24rem;padding:.22rem;border-radius:9px;border:1px solid var(--border);background:#fbf4ea}.map-type-segmented button{min-height:26px;border:1px solid transparent;border-radius:7px;background:transparent;color:#725a43;font-size:.72rem;font-weight:600}.map-type-segmented button.active{background:#fff;border-color:var(--border);color:#2f2419}.find-places-controls{display:grid;gap:.4rem}.find-places-controls input,.export-grid button,.export-between select{width:100%;min-height:32px;border:1px solid var(--border);border-radius:8px;padding:.42rem .58rem;background:#fff;color:var(--text);font-size:.82rem}.export-grid button{background:#b45e2f;border-color:#b45e2f;color:#fff;font-weight:600}.find-input-row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:.4rem}.secondary-button{min-height:32px;border:1px solid var(--border);border-radius:8px;background:#fff;color:#5a4530;font-size:.78rem;padding:.42rem .58rem}.places-results{border:1px solid var(--border);border-radius:8px;background:#fcf8f2;max-height:230px;overflow:auto;display:grid;gap:.35rem;padding:.42rem}.places-state{font-size:.77rem;color:var(--muted);padding:.2rem .1rem}.places-state-error{color:#ab3f2c}.place-result-row{border:1px solid var(--border);border-radius:8px;background:#fff;display:grid;grid-template-columns:minmax(0,1fr) auto;gap:.45rem;align-items:center;padding:.4rem .45rem}.place-result-main{min-width:0;display:grid;gap:.1rem}.place-result-main p{font-size:.79rem;font-weight:620;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.place-result-main small{font-size:.72rem;color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.place-type-chip{justify-self:start;margin-top:.1rem;border-radius:999px;border:1px solid #e2ccb1;background:#f7eddf;color:#7b6147;font-size:.67rem;line-height:1;padding:.16rem .42rem;text-transform:capitalize}.place-add-button{min-height:28px;border:1px solid #d59f6f;border-radius:7px;background:var(--accent-bg);color:#8d4e23;font-size:.75rem;font-weight:700;padding:.2rem .48rem}.place-add-button:disabled{opacity:.55;cursor:not-allowed}.export-grid button:disabled{opacity:.5;cursor:not-allowed}.placeholder-results{border:1px dashed #d8c5ae;border-radius:8px;background:#fcf7ef;padding:.48rem;display:grid;gap:.2rem}.placeholder-results p{font-size:.77rem;color:#7b6147}.waypoint-list-scroll{max-height:270px;overflow:auto;display:grid;gap:.55rem;padding-right:.15rem;padding-bottom:.55rem}.waypoint-row{border:1px solid var(--border);border-radius:9px;background:#fff;padding:.54rem .58rem;display:flex;align-items:center;gap:.52rem;min-height:86px;height:86px;position:relative;overflow:visible;transition:margin .18s ease,transform .18s ease,box-shadow .18s ease,border-color .18s ease}.waypoint-row.is-dragging{opacity:.6;transform:scale(.985)}.waypoint-row.drop-target{margin-top:12px}.waypoint-row.drop-target:before{content:"";position:absolute;left:0;right:0;top:-8px;height:4px;border-radius:999px;background:#d8a36e}.waypoint-main{display:flex;align-items:center;gap:.54rem;flex:1;min-width:0}.waypoint-order-picker{width:30px;min-width:30px;max-width:30px;height:30px;min-height:30px;max-height:30px;margin-left:.08rem;border-radius:999px;color:#fff;font-size:.68rem;font-weight:700;font-variant-numeric:tabular-nums;letter-spacing:0;line-height:1;display:inline-flex;align-items:center;justify-content:center;position:relative;overflow:hidden;border:2px solid #ffffff;box-shadow:0 0 0 1px #10182814;cursor:pointer}.waypoint-order-picker input[type=color]{position:absolute;top:0;right:0;bottom:0;left:0;opacity:0;cursor:pointer}.waypoint-label{font-size:.82rem;font-weight:620;line-height:1.2;display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%}.waypoint-details small{color:var(--muted);font-size:.73rem;display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.waypoint-details{min-width:0;display:grid;gap:.08rem}.waypoint-label-button,.waypoint-coords-button{border:0;background:transparent;padding:0;margin:0;text-align:left;width:100%;min-width:0}.waypoint-actions{display:inline-flex;align-items:center;gap:.28rem;flex-shrink:0}.grip-button{width:28px;height:34px;border:1px solid var(--border);border-radius:7px;background:#fff;display:grid;grid-template-columns:repeat(2,1fr);grid-template-rows:repeat(3,1fr);gap:2px;padding:5px 6px;align-items:center;justify-items:center;flex-shrink:0}.grip-button span{width:4px;height:4px;border-radius:50%;background:#b49a7f}.delete-waypoint{min-height:28px;border:1px solid #efc6bb;border-radius:7px;background:#fdeee8;color:#ab3f2c;font-size:.73rem;padding:.2rem .52rem;flex-shrink:0}.waypoint-shift-button{width:26px;min-height:28px;border:1px solid var(--border);border-radius:7px;background:#fff;color:#6a523b;font-size:.76rem;line-height:1;flex-shrink:0}.waypoint-shift-button:disabled{opacity:.45;cursor:not-allowed}.waypoint-overflow-popover{position:absolute;left:5rem;right:.62rem;top:calc(100% + .35rem);border:1px solid var(--border);border-radius:9px;background:#fff;box-shadow:0 8px 24px #0f172a1f;padding:.45rem .55rem;display:grid;gap:.12rem;z-index:25}.waypoint-overflow-popover p{font-size:.8rem;font-weight:620;color:var(--text);line-height:1.25}.waypoint-overflow-popover small{font-size:.72rem;color:var(--muted);line-height:1.3}.export-grid{display:grid;gap:.52rem}.export-between{display:grid;gap:.4rem}.export-between label{display:grid;gap:.2rem;font-size:.75rem;color:var(--muted)}.export-format{display:flex;align-items:center;gap:.8rem;font-size:.78rem}.export-format label{display:inline-flex;align-items:center;gap:.25rem}.elevation-section{padding-bottom:.52rem}.elevation-stats{display:flex;gap:.6rem;flex-wrap:wrap;margin-bottom:.42rem}.elevation-stat{display:inline-flex;align-items:center;gap:.18rem;font-size:.72rem;font-weight:650;color:#6b4225;background:#fdf0e4;border:1px solid #e8c9a8;border-radius:5px;padding:.1rem .42rem}.elevation-stat-icon{font-size:.6rem;opacity:.7}.elevation-stat-range{color:var(--muted);background:var(--surface-alt);border-color:var(--border)}.elevation-chart{display:block;width:100%;height:72px;border-radius:6px;overflow:hidden;background:#fdf8f2;border:1px solid var(--border)}.elevation-axis{display:flex;justify-content:space-between;font-size:.65rem;color:var(--muted);margin-top:.22rem;padding:0 .1rem}.export-utility-row{display:grid;grid-template-columns:1fr 1fr;gap:.4rem}.export-utility-btn{display:inline-flex;align-items:center;justify-content:center;gap:.3rem;min-height:32px;border:1px solid var(--border);border-radius:8px;background:#fff;color:#5a4530;font-size:.76rem;font-weight:600;padding:.3rem .5rem;cursor:pointer;transition:background .12s}.export-utility-btn:hover:not(:disabled){background:var(--accent-bg);border-color:#c7a484}.export-utility-btn:disabled{opacity:.45;cursor:default}.export-import-input{display:none}.route-sections-list{display:grid;gap:.36rem;max-height:260px;overflow-y:auto;overflow-x:hidden;padding-right:.12rem}.route-sections-list::-webkit-scrollbar{width:8px}.route-sections-list::-webkit-scrollbar-thumb{background:#dec8b0;border-radius:999px}.route-sections-list::-webkit-scrollbar-track{background:#f6efe6;border-radius:999px}.route-section-row{border:1px solid var(--border);border-radius:8px;background:#fcf7ef;color:var(--text);padding:.45rem .5rem;text-align:left;display:grid;gap:.12rem}.route-section-row p{font-size:.77rem;font-weight:600}.route-section-row small{font-size:.72rem;color:var(--muted)}.route-section-row.selected{border-color:#d7a577;background:#f9e8d7;box-shadow:inset 0 0 0 1px #c88552}.focused-leg-insights{border:1px solid var(--border);border-radius:8px;background:#fcf8f2;padding:.5rem;display:grid;gap:.4rem}.focused-leg-title{font-size:.76rem;font-weight:650;color:#5b4330}.focused-leg-grid{display:grid;gap:.35rem}.focused-leg-grid article{border:1px solid var(--border);border-radius:7px;background:#fff;padding:.38rem .42rem;display:grid;gap:.12rem}.focused-leg-label{font-size:.69rem;color:var(--muted);text-transform:uppercase;letter-spacing:.03em}.focused-leg-value{font-size:.78rem;font-weight:650;color:var(--text)}.focused-leg-grid small{font-size:.72rem;color:#7b6147}.empty-message{font-size:.77rem;color:var(--muted);border:1px dashed #d8c7b2;border-radius:8px;background:#fcf8f2;padding:.46rem}.planner-map-pane{min-width:0;min-height:0;position:relative;overflow:hidden;background:#ebe1d2}.map-overlay-controls{position:absolute;top:.7rem;z-index:30;display:inline-flex;align-items:center;gap:.45rem}.map-overlay-left{left:.8rem}.map-overlay-right{right:.8rem}.map-overlay-elevation{position:absolute;top:3.3rem;right:.8rem;z-index:30}.map-overlay-button{width:auto;min-height:36px;border-radius:10px;padding:.42rem .88rem;font-size:.92rem;font-weight:650;line-height:1;box-shadow:0 8px 18px #0f172a29}.elevation-toggle-button{min-height:34px;border:1px solid #dcb28e;border-radius:999px;background:linear-gradient(180deg,#fff6ea,#f9e6d3);color:#7a4d2f;display:inline-flex;align-items:center;gap:.35rem;padding:.34rem .62rem;box-shadow:0 7px 16px #5639222e}.elevation-toggle-button.active{border-color:#c57542;background:linear-gradient(180deg,#ffd3aa,#f3b47f);color:#5f3114}.elevation-toggle-icon{width:15px;height:15px}.elevation-toggle-text{font-size:.76rem;font-weight:700;letter-spacing:.01em}.elevation-toggle-state{min-width:32px;text-align:center;font-size:.67rem;font-weight:700;border-radius:999px;padding:.09rem .34rem;background:#ffffff9e}.map-type-visual-button{display:grid;justify-items:center;gap:.18rem;border:0;background:transparent;padding:.06rem 0;color:#5a4530;font-weight:700;width:100%}.map-type-visual-image{width:48px;height:48px;border-radius:12px;border:2px solid transparent;box-shadow:0 4px 10px #0f172a24}.map-type-visual-button.active{color:#b45e2f}.map-type-visual-button.active .map-type-visual-image{border-color:#b45e2f;box-shadow:0 0 0 2px #b45e2f3d,0 8px 16px #37251433}.map-confirm-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;z-index:40;display:grid;place-items:center;background:#0f172a5c}.map-confirm-dialog{width:min(360px,calc(100% - 2rem));border:1px solid var(--border);border-radius:12px;background:#fff;box-shadow:0 22px 40px #0f172a52;padding:.85rem .95rem;display:grid;gap:.45rem}.map-confirm-dialog h3{font-size:.95rem}.map-confirm-dialog p{font-size:.78rem;color:#6a523b}.map-note-dialog{width:min(420px,calc(100% - 2rem))}.map-note-input{width:100%;border:1px solid var(--border);border-radius:8px;background:#fff;color:var(--text);font:inherit;font-size:.82rem;line-height:1.35;padding:.55rem .62rem;resize:vertical;min-height:90px}.map-route-name-input{width:100%;border:1px solid var(--border);border-radius:8px;background:#fff;color:var(--text);font:inherit;font-size:.82rem;line-height:1.35;padding:.55rem .62rem;min-height:38px}.map-note-body{border:1px solid var(--border);border-radius:8px;background:#fcf8f2;color:#5a4530;padding:.55rem .62rem;font-size:.82rem;line-height:1.35;white-space:pre-wrap}.map-note-inline{max-width:250px;border:1px solid #dfb992;border-radius:10px;border-left:4px solid #c7743b;background:#fff7edfa;color:#7b4a26;font-size:.76rem;font-weight:620;letter-spacing:.005em;line-height:1.32;padding:.44rem .56rem;white-space:normal;word-break:break-word;box-shadow:0 6px 14px #55381f29}.map-note-inline-title{margin:0 0 .14rem;font-size:.74rem;font-weight:760;color:#6d3f1f;line-height:1.2}.map-note-inline-body{margin:0;font-size:.75rem;font-weight:560;line-height:1.3}.map-note-delete-button{margin-top:.42rem;min-height:28px;border:1px solid #efc6bb;border-radius:7px;background:#fdeee8;color:#ab3f2c;font-size:.72rem;font-weight:700;padding:.2rem .52rem}.marker-popup{min-width:240px;max-width:290px;padding:.62rem .72rem .58rem;border-radius:10px;background:#fff7edfc;border:1px solid #dfb992;border-left:4px solid #c7743b;box-shadow:0 6px 16px #55381f2e;display:grid;gap:.38rem;color:#4a2f14;font-family:Sora,sans-serif}.marker-popup-header{display:flex;align-items:center;gap:.5rem}.marker-popup-dot{flex-shrink:0;width:14px;height:14px;border-radius:50%;border:2px solid rgba(255,255,255,.85);box-shadow:0 0 0 1px #0000001f}.marker-popup-title{font-size:.82rem;font-weight:760;color:#5c3215;line-height:1.2;word-break:break-word}.marker-popup-coords{font-size:.68rem;color:#9a7255;letter-spacing:.02em;font-weight:500}.marker-popup-note-label{font-size:.7rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:#7a5232;margin-top:.1rem}.marker-popup-note-input{width:100%;min-height:64px;border:1px solid #dac4ae;border-radius:7px;background:#fff;color:#2f2419;font-size:.78rem;font-family:Sora,sans-serif;padding:.38rem .48rem;resize:vertical;line-height:1.4}.marker-popup-note-input:focus{outline:none;border-color:#c7743b;box-shadow:0 0 0 2px #c7743b2e}.marker-popup-actions{display:flex;gap:.4rem;margin-top:.1rem}.marker-popup-save-btn{flex:1;min-height:30px;border:none;border-radius:7px;background:#c7743b;color:#fff;font-size:.74rem;font-weight:700;cursor:pointer;transition:background .15s}.marker-popup-save-btn:hover{background:#a85e2c}.marker-popup-delete-btn{min-height:30px;padding:0 .7rem;border:1px solid #efc6bb;border-radius:7px;background:#fdeee8;color:#ab3f2c;font-size:.74rem;font-weight:700;cursor:pointer;transition:background .15s}.marker-popup-delete-btn:hover{background:#f9dbd4}.marker-list-card{border:1px solid var(--border);border-radius:10px;margin:0 .8rem .8rem;padding:.62rem .72rem;background:#fdf8f2}.marker-list-heading{margin:0;font-size:.74rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:#5c4633}.marker-list{list-style:none;margin:.42rem 0 0;padding:0;display:grid;gap:.32rem;max-height:220px;overflow-y:auto}.marker-list-item{display:flex;align-items:flex-start;gap:.48rem;padding:.38rem .44rem;border-radius:7px;background:#fff;border:1px solid #e8d8c8}.marker-list-dot{flex-shrink:0;width:12px;height:12px;border-radius:50%;margin-top:3px;border:1.5px solid rgba(255,255,255,.8);box-shadow:0 0 0 1px #0000001a}.marker-list-info{flex:1;min-width:0;display:grid;gap:.1rem}.marker-list-title{font-size:.78rem;font-weight:700;color:#3a2510;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.marker-list-note{font-size:.72rem;color:#7a5a3a;line-height:1.3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.marker-list-coords{font-size:.66rem;color:#a08060;letter-spacing:.01em}.marker-list-delete{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:1px solid #efc6bb;border-radius:6px;background:transparent;color:#ab3f2c;cursor:pointer;transition:background .12s}.marker-list-delete:hover{background:#fdeee8}.map-confirm-actions{margin-top:.25rem;display:flex;justify-content:flex-end;gap:.4rem}.planner-route-library-list{max-height:260px;overflow:auto;display:grid;gap:.42rem;padding-right:.1rem}.planner-route-library-row{border:1px solid var(--border);border-radius:9px;background:#fff;color:var(--text);text-align:left;padding:.46rem .52rem;display:grid;grid-template-columns:minmax(0,1fr) auto;gap:.4rem;align-items:center}.planner-route-library-info{min-width:0;display:grid;gap:.12rem}.planner-route-library-row strong{font-size:.79rem;font-weight:680}.planner-route-library-row small{font-size:.72rem;color:var(--muted)}.planner-route-library-actions{display:inline-flex;align-items:center;gap:.3rem}.planner-route-open-button,.planner-route-delete-button{min-height:28px;border-radius:7px;font-size:.72rem;font-weight:700;padding:.2rem .5rem}.planner-route-open-button{border:1px solid #dec8b0;background:#fffaf3;color:#7b5838}.planner-route-delete-button{border:1px solid #efc6bb;background:#fdeee8;color:#ab3f2c}.planner-map-pane.leg-selected{box-shadow:inset 0 0 0 2px #b45e2f73}.planner-map-canvas{width:100%;height:100%}.map-status{position:absolute;bottom:.7rem;left:.8rem;margin:0;font-size:.75rem;padding:.3rem .5rem;border-radius:6px;border:1px solid var(--border);background:#ffffffe6;color:#5d4936}.map-status-route{left:auto;right:.8rem}.map-status-top{top:4.2rem;bottom:auto;left:.8rem;max-width:min(65%,420px)}.map-status-success{border-color:#d8aa7a;background:#fff6eaf2;color:#8d4e23}.map-status-info{border-color:#e7c391;background:#fff8ecf2;color:#8d4e23}.map-status-error{border-color:#efc0b5;background:#fdeee8;color:#ab3f2c}.mini-icon-button .control-icon{width:20px;height:20px}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}button:focus-visible,input:focus-visible,select:focus-visible,a:focus-visible{outline:2px solid var(--focus-ring);outline-offset:2px}@media(max-width:1140px){.planner-body{grid-template-columns:58px 320px minmax(0,1fr)}.planner-header{padding:0 .75rem}.planner-brand-logo{height:30px;max-width:120px}.planner-brand-title{font-size:.82rem}.planner-brand-subtitle{font-size:.65rem}.planner-sidebar{padding-top:.2rem}}@media(max-width:980px){.planner-body{grid-template-columns:54px 300px minmax(0,1fr)}.planner-toolbar{gap:.3rem}.map-type-segmented button{font-size:.69rem}}@media(max-width:980px){.planner-workspace-shell{grid-template-rows:56px minmax(0,1fr)}.planner-brand-subtitle{display:none}.planner-body{grid-template-columns:1fr;grid-template-rows:auto auto minmax(0,1fr)}.planner-mini-sidebar{grid-template-rows:auto;grid-template-columns:auto 1fr;justify-items:start;align-items:center;gap:.85rem;padding:.45rem .55rem;border-right:0;border-bottom:1px solid var(--border)}.mini-sidebar-top{grid-auto-flow:column;grid-auto-columns:max-content;gap:.7rem;align-items:center}.mini-route-style-toggle{grid-auto-flow:column;grid-auto-columns:max-content;margin-top:0;gap:.36rem}.map-overlay-elevation{top:3.15rem;right:.55rem}.mini-sidebar-bottom{align-self:center;justify-self:start;grid-auto-flow:column;grid-auto-columns:max-content;gap:.7rem;width:auto;padding:0}.planner-sidebar{max-height:45vh;border-right:0;border-bottom:1px solid var(--border)}.route-ai-actions,.route-explorer-grid,.route-explorer-actions,.marker-color-grid{grid-template-columns:1fr}.route-ai-dialog{width:min(760px,98vw);max-height:84vh}.map-type-visual-image{width:46px;height:46px;border-radius:11px}}.auth-page{min-height:100vh;position:relative;display:grid;place-items:center;padding:1.5rem;background:#f6f1e8}.auth-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 12% 16%,#ffbc6740,#ffbc6700 42%),radial-gradient(circle at 82% 88%,#db5a3738,#db5a3700 45%),linear-gradient(180deg,#ffffffc7,#ffffffe6)}.auth-card{position:relative;width:min(460px,100%);border:1px solid #e3d4c2;border-radius:18px;background:#fffffff5;box-shadow:0 20px 48px #53361c2e;padding:1.2rem 1.2rem 1rem;display:grid;gap:.9rem}.auth-card-header{display:grid;gap:.22rem}.auth-kicker{font-size:.7rem;letter-spacing:.09em;text-transform:uppercase;color:#a17f5c;font-weight:700}.auth-card-header h1{font-size:1.22rem;font-weight:760;color:#2f2419}.auth-subtitle{color:#7a6856;font-size:.84rem}.auth-mode-toggle{display:grid;grid-template-columns:repeat(2,1fr);border:1px solid #e4cfb9;border-radius:11px;background:#fdf7ef;padding:.2rem}.auth-mode-toggle button{border:0;background:transparent;color:#725a43;font-weight:650;min-height:34px;border-radius:8px}.auth-mode-toggle button.active{background:#f9e8d7;color:#8d4e23;box-shadow:inset 0 0 0 1px #d6a06f}.auth-form{display:grid;gap:.65rem}.auth-form label{display:grid;gap:.24rem;font-size:.77rem;color:#6e5a46;font-weight:620}.auth-form input{width:100%;min-height:38px;border:1px solid #dec9b3;border-radius:10px;padding:.5rem .62rem;background:#fff;color:#2f2419}.auth-form input:focus-visible{outline:2px solid #c7743b;outline-offset:1px}.auth-primary-button{min-height:40px;border:1px solid #b45e2f;border-radius:10px;background:linear-gradient(180deg,#c86b36,#b45e2f);color:#fff;font-weight:700}.auth-primary-button:disabled{opacity:.72;cursor:not-allowed}.auth-divider{position:relative;text-align:center;color:#90765d;font-size:.76rem}.auth-divider:before{content:"";position:absolute;top:50%;left:0;right:0;border-top:1px solid #eadac9}.auth-divider span{position:relative;padding:0 .5rem;background:#fffdfb}.auth-google-button{min-height:40px;border:1px solid #dec9b3;border-radius:10px;background:#fff;color:#5a4530;display:inline-flex;align-items:center;justify-content:center;gap:.48rem;font-weight:650}.auth-google-mark{width:18px;height:18px;display:block;object-fit:contain}.auth-link-inline{justify-self:start}.auth-secondary-link{text-decoration:none;color:#8d4e23;font-size:.8rem;font-weight:650}.auth-status{font-size:.78rem;color:#725a43}.auth-status-error{color:#ab3f2c}.auth-status-success{color:#8d4e23}.auth-account-panel{display:grid;gap:.55rem;border:1px solid #e5d4c4;border-radius:12px;background:#fdf7f0;padding:.75rem}.auth-account-row{display:flex;justify-content:space-between;gap:1rem;font-size:.82rem;color:#6e5a46}.auth-account-row strong{color:#2f2419}.auth-actions{display:grid;grid-template-columns:minmax(140px,200px) minmax(140px,200px);gap:.55rem;margin-top:.35rem;align-items:center}.auth-actions .auth-primary-button{min-height:42px;border-radius:11px;font-size:.85rem;letter-spacing:.01em}.auth-actions .auth-secondary-link{min-height:42px;border:1px solid #decab5;border-radius:11px;background:#fffaf4;color:#8d4e23;display:inline-flex;align-items:center;justify-content:center;padding:.2rem .7rem;font-size:.83rem;font-weight:700;text-decoration:none}.auth-actions .auth-secondary-link:hover{background:#f8eadb}.auth-routes-section{border:1px solid #e5d4c4;border-radius:12px;background:#fffaf4;padding:.72rem;display:grid;gap:.5rem}.auth-routes-header{display:flex;align-items:baseline;justify-content:space-between;gap:.5rem}.auth-routes-header h2{font-size:.95rem;color:#523920}.auth-routes-header small{font-size:.72rem;color:#8c6b4f}.auth-routes-table-wrap{max-height:220px;overflow:auto;border:1px solid #eadbcb;border-radius:9px}.auth-routes-table{width:100%;border-collapse:collapse;font-size:.76rem;color:#4b3a2a;background:#fff}.auth-routes-table th,.auth-routes-table td{text-align:left;padding:.42rem .52rem;border-bottom:1px solid #f0e4d8;vertical-align:middle}.auth-routes-table th{font-weight:700;color:#77583d;background:#fcf6ee;position:sticky;top:0;z-index:1}.auth-routes-table tbody tr:last-child td{border-bottom:0}.auth-routes-table th:last-child,.auth-routes-table td:last-child{text-align:right;width:1%;white-space:nowrap}.auth-route-delete-button{border:1px solid #e6c1ad;border-radius:8px;background:#fff6f2;color:#a64a2f;min-height:30px;padding:.2rem .58rem;font-size:.72rem;font-weight:700}.auth-route-delete-button:hover:not(:disabled){background:#ffe9df}.auth-route-delete-button:disabled{opacity:.7;cursor:not-allowed}@media(max-width:560px){.auth-page{padding:1rem}.auth-card{padding:1rem .92rem .9rem;border-radius:14px}.auth-actions{grid-template-columns:1fr}}.site-shell{min-height:100vh;display:grid;grid-template-rows:56px minmax(0,1fr) auto;background:#f6f1e8}.site-header.site-header-static{position:sticky;top:0;z-index:110}.planner-header.site-header{background:#f2eadf}.site-header.site-header-static .planner-branding{margin-left:max(clamp(1rem,4vw,3.2rem),calc((100vw - 1380px)/2))}@media(max-width:980px){.site-header.site-header-static .planner-branding{margin-left:0}}.site-main{padding:2rem 1.2rem 2.4rem}.site-nav{display:inline-flex;align-items:center;gap:.3rem}.site-nav a{min-height:40px;border:1px solid transparent;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;padding:0 .95rem;font-size:.96rem;font-weight:700;color:#6d5844;text-decoration:none}.site-nav a:hover{background:#f7eee4}.site-nav a.active{border-color:#dcc6ae;background:#fff8ef;color:#8d4e23}.site-footer{border-top:1px solid #e7dac9;background:#fffdf9;padding:.85rem 1.2rem 1rem;display:grid;gap:.1rem}.site-footer p{font-size:.78rem;font-weight:700;color:#5b4330}.site-footer small{font-size:.72rem;color:#8b7259}.landing-hero{width:calc(100% + 2.4rem);margin:-2rem -1.2rem 0;min-height:clamp(420px,74vh,760px);display:flex;align-items:center;padding:clamp(1.2rem,6vw,4.2rem);background-image:linear-gradient(120deg,#15120fb3,#15120f61 42%,#15120f24 72%),url(/hero_background.jpg);background-size:cover;background-position:center;background-repeat:no-repeat}.landing-hero-copy{max-width:680px;display:grid;gap:.75rem}.landing-kicker{font-size:.88rem;text-transform:uppercase;letter-spacing:.08em;color:#a17853;font-weight:750}.landing-hero h1,.content-page h1{font-size:clamp(2.05rem,4vw,3.2rem);line-height:1.08;font-weight:800;text-wrap:balance}.landing-hero h1{color:#fffdf9}.landing-hero p{color:#f4e6d8;font-size:clamp(.98rem,1.55vw,1.12rem);max-width:62ch}.content-page p{color:#6f5b47;font-size:clamp(.86rem,1.8vw,1rem);max-width:62ch}.landing-hero-actions{margin-top:.58rem;display:inline-flex;align-items:center;gap:.62rem}.landing-cta-primary,.landing-cta-secondary{min-height:48px;border-radius:12px;padding:.62rem 1.08rem;display:inline-flex;align-items:center;justify-content:center;text-decoration:none;font-size:1rem;font-weight:700;line-height:1;transition:background-color .14s ease,border-color .14s ease,color .14s ease}.landing-cta-primary{border:1px solid #d08f60;background:#f9e8d7;color:#8d4e23}.landing-cta-secondary{border:1px solid #dcc4ab;background:#fffaf3;color:#7b5838}.landing-cta-primary:hover{background:#f5dec6}.landing-cta-secondary:hover{background:#f8eee1}.content-page{width:min(1100px,100%);margin:0 auto;border:1px solid #e4d4c2;border-radius:16px;background:#fffdf9;padding:clamp(1rem,2.4vw,1.8rem);display:grid;gap:.5rem}.landing-roadfield{width:calc(100% + 2.4rem);margin:0 -1.2rem -2.4rem;min-height:clamp(720px,92vh,1200px);background:radial-gradient(circle at 10% 18%,#d6ad7e38,#d6ad7e00 34%),radial-gradient(circle at 86% 72%,#b45e2f29,#b45e2f00 30%),linear-gradient(180deg,#efe6d8,#f6efe3);border-top:1px solid #e0d1bf;position:relative;overflow:hidden;padding:clamp(1.3rem,3vw,2.6rem) clamp(1rem,4vw,3.2rem)}.landing-roadfield:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:radial-gradient(circle at 12% 14%,#ffffff73,#fff0 40%),radial-gradient(circle at 78% 80%,#ffffff4d,#fff0 35%);pointer-events:none}.landing-road-svg{position:absolute;top:0;right:0;bottom:0;left:0;display:block;width:100%;height:100%;pointer-events:none}.landing-road-svg .lane{fill:none;stroke:#b86e3c;stroke-width:2.9;stroke-linecap:round;stroke-dasharray:.1 14;opacity:.74}.landing-road-svg .lane-a{stroke:#a95f31}.landing-road-svg .lane-b{stroke:#c47e4e;opacity:.62}.landing-road-content{position:relative;z-index:1;width:min(1380px,100%);margin:0 auto}.landing-intro-glass{width:min(1320px,100%);border:1px solid rgba(214,190,166,.72);border-radius:18px;background:#fffbf5;box-shadow:0 20px 46px #462f1c1f;backdrop-filter:none;-webkit-backdrop-filter:none;padding:clamp(1.4rem,2.8vw,2rem);display:grid;gap:1.25rem;position:relative;overflow:hidden}.landing-intro-glass:before{content:"";position:absolute;top:-1px;right:-1px;bottom:-1px;left:-1px;background:transparent;pointer-events:none}.landing-planner-explainer{margin-top:clamp(1.4rem,3.2vw,2.3rem);border:1px solid rgba(214,190,166,.72);border-radius:18px;background:#fffbf5;padding:clamp(1.1rem,2.4vw,1.8rem);display:grid;grid-template-columns:minmax(0,.88fr) minmax(0,1.12fr);gap:clamp(.9rem,2.4vw,1.4rem);align-items:start}.landing-pricing-section{margin-top:clamp(1.4rem,3.2vw,2.3rem);border:1px solid rgba(214,190,166,.72);border-radius:18px;background:#fffbf5;padding:clamp(1.1rem,2.4vw,1.8rem);display:grid;gap:.95rem}.landing-pricing-header{display:grid;gap:.32rem}.landing-pricing-header h2{margin:0;color:#352517;font-size:clamp(1.72rem,2.7vw,2.3rem)}.landing-pricing-header p{margin:0;color:#5f4a36;font-size:.94rem;line-height:1.42;max-width:75ch}.landing-pricing-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.7rem}.plan-card{border:1px solid #dcc4ab;border-radius:14px;background:#fff;padding:.95rem;display:grid;gap:.68rem}.plan-free{border-top:4px solid #d6a273}.plan-pro{border-top:4px solid #b45e2f;box-shadow:0 10px 22px #4e321a1f}.plan-top{display:flex;align-items:baseline;justify-content:space-between;gap:.5rem}.plan-name{margin:0;color:#4d3726;font-size:1.28rem;font-weight:800}.plan-price{margin:0;color:#7d4522;font-size:1.78rem;font-weight:800;line-height:1}.plan-price span{color:#8f6f54;font-size:.76rem;font-weight:700;margin-left:.15rem}.plan-tagline{margin:0;color:#6b5642;font-size:.85rem}.plan-features{margin:0;padding:0;list-style:none;display:grid;gap:.42rem}.plan-features li{position:relative;padding-left:1rem;color:#5b4734;font-size:.84rem;line-height:1.35}.plan-features li:before{content:"";position:absolute;left:.08rem;top:.46rem;width:.34rem;height:.34rem;border-radius:999px;background:#c77740}.plan-actions{margin-top:.22rem;display:flex;align-items:center}.landing-planner-copy{display:grid;gap:.62rem}.landing-planner-copy h2{margin:0;color:#352517;font-size:clamp(1.85rem,2.9vw,2.4rem);line-height:1.1}.landing-planner-copy>p{margin:0;color:#5f4a36;font-size:.94rem;line-height:1.45}.landing-planner-list{display:grid;gap:.5rem}.landing-planner-actions{margin-top:.2rem;display:flex;align-items:center}.landing-planner-item{border:1px solid rgba(213,189,165,.82);border-radius:11px;background:#ffffff6b;padding:.62rem .68rem}.landing-planner-item h3{margin:0;color:#493425;font-size:.9rem;font-size:1.02rem}.landing-planner-item p{margin:.16rem 0 0;color:#6a5642;font-size:.82rem;line-height:1.38}.landing-mac-window{border:1px solid #e5d4c4;border-radius:14px;background:#fff;overflow:hidden;box-shadow:0 16px 30px #3d291729}.landing-mac-toolbar{min-height:38px;border-bottom:1px solid #ece0d3;background:#f6eee3f2;display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:.5rem;padding:0 .72rem}.landing-mac-controls{display:inline-flex;align-items:center;gap:.35rem}.landing-mac-controls .dot{width:11px;height:11px;border-radius:999px;border:1px solid rgba(0,0,0,.12)}.landing-mac-controls .dot.red{background:#ff5f57}.landing-mac-controls .dot.yellow{background:#febc2e}.landing-mac-controls .dot.green{background:#28c840}.landing-mac-title{justify-self:center;font-size:.74rem;font-weight:700;color:#7b5d43}.landing-mac-body{background:#f7efe4cc}.landing-mac-image{display:block;width:100%;height:auto}.landing-mac-fallback{min-height:clamp(220px,38vw,430px);place-items:center;gap:.4rem;padding:1rem;text-align:center}.landing-mac-fallback svg{width:30px;height:30px;color:#8d4e23}.landing-mac-fallback p{margin:0;color:#6f5b47;font-size:.8rem}.landing-intro-head,.landing-intro-contrast,.landing-intro-points{position:relative;z-index:1}.landing-intro-head{display:grid;gap:.34rem}.landing-intro-head h2{margin:0;color:#352517;font-size:clamp(1.95rem,3.1vw,2.75rem);line-height:1.08}.landing-intro-lead{margin:0;color:#5f4a36;font-size:clamp(.98rem,1.45vw,1.1rem);line-height:1.45;max-width:78ch}.landing-intro-contrast{display:grid;grid-template-columns:minmax(0,1fr) auto minmax(0,1fr);gap:.58rem;align-items:stretch}.landing-intro-problem,.landing-intro-solution{border:1px solid rgba(211,183,157,.86);border-radius:12px;padding:.82rem .88rem;display:grid}.landing-intro-problem{background:#fff5e857}.landing-intro-solution{background:#f9e8d766}.landing-intro-mini{margin:0;text-transform:uppercase;letter-spacing:.06em;font-size:.67rem;font-weight:800;color:#8a5a35}.landing-intro-problem h3,.landing-intro-solution h3{margin:.2rem 0 0;color:#493425;font-size:1.18rem}.landing-intro-problem p,.landing-intro-solution p{margin:.2rem 0 0;color:#654f3a;font-size:.84rem;line-height:1.4}.landing-intro-flow{width:52px;border-radius:999px;border:1px dashed rgba(194,142,95,.8);background:#fffaf25c;display:grid;place-items:center}.landing-intro-flow svg{width:20px;height:20px;color:#9e6236}.landing-intro-points{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.56rem}.landing-intro-point{border:1px solid rgba(213,189,165,.82);border-radius:12px;background:#ffffff38;padding:.9rem .92rem;display:grid;grid-template-columns:auto 1fr;align-items:start;gap:.56rem}.landing-intro-point svg{width:19px;height:19px;color:#8d4e23;margin-top:.08rem}.landing-point-index{margin:0;font-size:.64rem;letter-spacing:.07em;font-weight:800;color:#97633c}.landing-intro-point h3{margin:.12rem 0 0;color:#493425;font-size:1.12rem;line-height:1.2}.landing-intro-point p{margin:.12rem 0 0;color:#6a5642;font-size:.84rem;line-height:1.38}.landing-intro-point.point-one{background:#fff9f047;transform:translateY(3px)}.landing-intro-point.point-two{background:#ffffff3d;transform:translateY(-3px)}.landing-intro-point.point-three{background:#fff4e642;transform:translateY(5px)}@media(max-width:980px){.site-shell{grid-template-rows:56px minmax(0,1fr) auto}.site-main{padding:1rem .6rem 1.5rem}.landing-hero{width:calc(100% + 1.2rem);margin:-1rem -.6rem 0;min-height:clamp(380px,68vh,620px);padding:1.15rem;background-position:62% center}.landing-roadfield{width:calc(100% + 1.2rem);margin:0 -.6rem -1.5rem;min-height:clamp(620px,85vh,900px);padding:1rem .72rem 1.4rem}.landing-intro-glass{width:100%;border-radius:14px;padding:1rem}.landing-intro-contrast{grid-template-columns:1fr}.landing-intro-flow{width:100%;min-height:36px}.landing-intro-points{grid-template-columns:1fr}.landing-intro-point.point-one,.landing-intro-point.point-two,.landing-intro-point.point-three{transform:none}.landing-planner-explainer{margin-top:1.1rem;grid-template-columns:1fr;padding:1rem}.landing-pricing-section{margin-top:1.1rem;padding:1rem}.landing-pricing-grid{grid-template-columns:1fr}.site-nav{display:none}}
