:root{--bg:#f6f9fc;--panel:rgba(255,255,255,0.82);--panel-strong:#ffffff;--line:rgba(57,78,102,0.14);--text:#1d2a38;--muted:#687789;--blue:#61a8f7;--cyan:#58c7dc;--green:#80d9b4}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;background:linear-gradient(180deg,#f9fcff,#eef6fb 54%,#f7f9fb);color:var(--text);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Noto Sans TC,sans-serif}button,input,select,textarea{font:inherit}button,label{-webkit-tap-highlight-color:transparent}.app-shell{display:grid;grid-template-columns:260px minmax(0,1fr);min-height:100vh}.sidebar{position:-webkit-sticky;position:sticky;top:0;height:100vh;padding:24px;border-right:1px solid var(--line);background:rgba(255,255,255,.76);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.brand,.status-card{display:flex;align-items:center;gap:12px}.brand-mark{display:grid;width:44px;height:44px;place-items:center;border:1px solid rgba(88,199,220,.4);border-radius:8px;background:linear-gradient(145deg,rgba(97,168,247,.28),rgba(128,217,180,.2))}.brand-mark svg{width:28px;height:28px;fill:rgba(36,82,127,.18);stroke:#24527f;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.brand span,.brand strong,.status-card small,.status-card strong{display:block}.brand span,.muted,.status-card small{color:var(--muted);font-size:12px}nav{display:grid;grid-gap:8px;gap:8px;margin-top:40px}nav a{padding:11px 12px;border-radius:8px;color:var(--muted);text-decoration:none}nav a:hover{background:rgba(97,168,247,.13);color:var(--text)}.status-card{position:absolute;right:24px;bottom:24px;left:24px;padding:14px;border:1px solid var(--line);border-radius:8px;background:rgba(255,255,255,.7)}.status-card>span{width:10px;height:10px;border-radius:50%;background:var(--green);box-shadow:0 0 18px var(--green)}.content{min-width:0}.hero{position:relative;min-height:620px;display:grid;align-content:center;overflow:hidden;padding:80px min(10vw,140px);border-bottom:1px solid var(--line)}.hero:before{content:"";background-image:linear-gradient(rgba(71,101,130,.08) 1px,transparent 0),linear-gradient(90deg,rgba(71,101,130,.08) 1px,transparent 0);background-size:72px 72px;-webkit-mask-image:linear-gradient(180deg,black,transparent 92%);mask-image:linear-gradient(180deg,black,transparent 92%)}.hero-lines,.hero:before{position:absolute;inset:0}.hero-lines{pointer-events:none}.hero-lines i{position:absolute;display:block;border:1px solid rgba(88,199,220,.34)}.hero-lines i:first-child{top:20%;right:17%;width:220px;height:220px;border-radius:50%}.hero-lines i:nth-child(2){top:50%;right:28%;width:130px;height:130px;border-radius:50%}.hero-lines i:nth-child(3){top:45%;right:19%;width:380px;height:2px;border:0;background:linear-gradient(90deg,transparent,var(--cyan),transparent);transform:rotate(15deg)}.hero>:not(.hero-lines){position:relative;z-index:1}.eyebrow{margin:0 0 12px;color:#29a5bd;font-size:12px;font-weight:800;letter-spacing:0;text-transform:uppercase}h1,h2,h3,p{margin-top:0}h1{max-width:720px;margin-bottom:18px;font-size:clamp(36px,5.2vw,68px);line-height:1.05;letter-spacing:0}.hero-copy{max-width:620px;color:#506174;font-size:18px;line-height:1.7}.hero-actions,.report-actions{display:flex;flex-wrap:wrap;gap:12px}.run-button,button{min-height:44px;border:1px solid rgba(97,168,247,.42);border-radius:8px;background:var(--blue);color:white;font-weight:800;cursor:pointer}.report-actions button,button.secondary{background:rgba(255,255,255,.76);color:var(--text)}button:disabled{cursor:wait;opacity:.7}.hero-actions button,.report-actions button{padding:12px 16px}.report,.results,.saved,.workspace{width:min(1180px,calc(100% - 48px));margin:0 auto}.workspace{display:grid;grid-template-columns:350px minmax(0,1fr);grid-gap:18px;gap:18px;padding:42px 0}.panel{border:1px solid var(--line);border-radius:8px;background:var(--panel);box-shadow:0 24px 80px rgba(62,83,108,.12);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.preview-panel,.report,.result-card,.saved,.upload-panel{padding:18px}.drop-zone{display:grid;min-height:180px;place-items:center;grid-gap:8px;gap:8px;margin:18px 0;padding:18px;border:1px dashed rgba(88,199,220,.44);border-radius:8px;background:rgba(255,255,255,.56);color:var(--muted);text-align:center;cursor:pointer}.drop-zone input{display:none}.drop-zone span{display:grid;width:42px;height:42px;place-items:center;border-radius:50%;background:rgba(97,168,247,.16);color:#229fc1;font-size:28px}.drop-zone strong{color:var(--text)}.field{display:grid;grid-gap:10px;gap:10px;margin-top:16px}.field-label{color:#29a5bd;font-size:12px;font-weight:800}.segments{display:grid;grid-template-columns:repeat(2,1fr);grid-gap:4px;gap:4px;padding:4px;border:1px solid var(--line);border-radius:8px;background:rgba(255,255,255,.62)}.segments button{height:38px;border:0;border-radius:6px;background:transparent;color:var(--muted)}.segments button.active{background:rgba(97,168,247,.2);color:var(--text)}select{width:100%;height:44px;border:1px solid var(--line);border-radius:8px;background:white;color:var(--text);padding:0 12px}.run-button{width:100%;margin-top:18px}.analysis-status{min-height:22px;margin:10px 0 0;color:var(--muted);font-size:13px;line-height:1.5}.image-stage{position:relative;display:grid;min-height:460px;overflow:hidden;place-items:center;border:1px solid var(--line);border-radius:8px;background:#f1f6fb}.image-stage img{position:absolute;inset:0;width:100%;height:100%;object-fit:contain}.empty-preview{color:var(--muted);font-weight:800}.overlay{inset:0;pointer-events:none}.overlay,.thirds{position:absolute}.thirds{background:rgba(88,199,220,.52)}.thirds.x1,.thirds.x2{top:0;width:1px;height:100%}.thirds.x1{left:33.33%}.thirds.x2{left:66.66%}.thirds.y1,.thirds.y2{left:0;width:100%;height:1px}.thirds.y1{top:33.33%}.thirds.y2{top:66.66%}.focus-circle{position:absolute;left:43%;top:32%;width:18%;aspect-ratio:1;border:2px solid rgba(97,168,247,.72);border-radius:50%}.flow-arrow{position:absolute;left:20%;width:42%;height:2px;background:linear-gradient(90deg,transparent,#229fc1);transform-origin:left center}.flow-arrow.one{top:61%;transform:rotate(-18deg)}.flow-arrow.two{top:30%;transform:rotate(14deg)}.overlay.street .focus-circle{border-color:rgba(128,217,180,.82)}.overlay.street .flow-arrow{background:linear-gradient(90deg,transparent,var(--green))}.results{padding:16px 0 42px}.section-header h2{margin-bottom:18px}.result-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));grid-gap:14px;gap:14px}.result-grid.single-result,.result-grid.street-result{grid-template-columns:minmax(0,1fr)}.principles-result{display:grid;grid-template-columns:minmax(0,.9fr) minmax(320px,1.1fr);grid-column-gap:24px;column-gap:24px;align-items:start}.principles-result .tag-row,.principles-result .total-score,.principles-result h3,.principles-result p{grid-column:1}.principles-result .principle-list{grid-column:2;grid-row:1/span 4}.street-redesign-card{display:grid;grid-template-columns:minmax(280px,.72fr) minmax(360px,1.28fr);grid-gap:18px 24px;gap:18px 24px;align-items:start}.street-redesign-card h3,.street-redesign-card p,.street-redesign-card ul{grid-column:1}.street-redesign-card .generated-figure{grid-column:2;grid-row:1/span 3}.result-card{min-height:280px}.card-index{color:#29a5bd;font-weight:900}.result-card h3{margin:8px 0 14px}.result-card li,.result-card p{color:#4f6072;line-height:1.65}.generated-figure{margin:14px 0}.generated-figure img{display:block;width:100%;border:1px solid var(--line);border-radius:8px;background:#eef5fa}.generated-figure figcaption{margin-top:8px;color:var(--muted);font-size:12px}.tag-row{display:flex;flex-wrap:wrap;gap:8px}.total-score{display:flex;align-items:baseline;justify-content:space-between;gap:12px;margin:14px 0;padding:12px;border:1px solid rgba(97,168,247,.18);border-radius:8px;background:rgba(97,168,247,.08);color:#2e5f92;font-weight:800}.total-score strong{color:var(--text);font-size:28px;line-height:1}.tag-row span{padding:7px 9px;border:1px solid var(--line);border-radius:999px;background:rgba(97,168,247,.1);color:#2e5f92;font-size:12px}.principle-list{display:grid}.principle-item{display:grid;grid-template-columns:52px minmax(0,1fr) 42px;align-items:center;grid-gap:8px;gap:8px;padding:8px 0;border-bottom:1px solid var(--line)}.principle-item span{font-size:13px;font-weight:800}.principle-item div{height:8px;overflow:hidden;border-radius:999px;background:rgba(97,168,247,.16)}.principle-item i{display:block;height:100%;border-radius:inherit;background:linear-gradient(90deg,var(--blue),var(--green))}.principle-item strong{color:#2e5f92;font-size:13px;text-align:right}.metric-row{display:flex;justify-content:space-between;gap:12px;padding:12px 0;border-top:1px solid var(--line);color:var(--muted)}.metric-row strong{color:var(--text)}.report{display:grid;grid-template-columns:minmax(0,1fr) auto;grid-gap:18px;gap:18px;margin-bottom:48px}textarea{width:100%;min-height:260px;resize:vertical;border:1px solid var(--line);border-radius:8px;background:rgba(255,255,255,.72);color:#293849;padding:14px;line-height:1.55}.report-actions{align-content:start;margin-top:42px}.saved{display:grid;grid-template-columns:260px minmax(0,1fr);grid-gap:18px;gap:18px;margin-bottom:48px}.saved p{color:#4f6072;line-height:1.65}.saved-right{display:flex;flex-direction:column;gap:14px;min-width:0}.saved-tabs{display:flex;gap:8px}.saved-tabs button{padding:6px 16px;border:1px solid var(--line);border-radius:20px;background:rgba(255,255,255,.6);color:var(--muted);font-size:13px;font-weight:600;cursor:pointer;transition:all .15s}.saved-tabs button.active{background:var(--accent,#29a5bd);border-color:var(--accent,#29a5bd);color:#fff}.saved-list{display:grid;grid-gap:10px;gap:10px}.saved-item{display:grid;grid-template-columns:72px minmax(0,1fr) auto auto;align-items:center;grid-gap:12px;gap:12px;padding:10px;border:1px solid var(--line);border-radius:8px;background:rgba(255,255,255,.58)}.saved-item img{width:72px;height:56px;border-radius:6px;object-fit:cover;background:#eef5fa}.saved-item small,.saved-item span,.saved-item strong{display:block}.empty-saved,.saved-item small,.saved-item span{color:var(--muted);font-size:12px}.saved-item button{min-height:36px;padding:0 12px}.saved-item button.danger{border-color:rgba(220,95,95,.26);background:rgba(255,255,255,.76);color:#9a3d3d}@media (max-width:1080px){.app-shell{grid-template-columns:1fr}.sidebar{position:relative;height:auto}.status-card{display:none}.workspace{grid-template-columns:1fr 1fr}.result-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width:720px){.principles-result,.report,.result-grid,.saved,.street-redesign-card,.workspace{grid-template-columns:1fr}.principles-result .principle-list,.principles-result .tag-row,.principles-result .total-score,.principles-result h3,.principles-result p,.street-redesign-card .generated-figure,.street-redesign-card h3,.street-redesign-card p,.street-redesign-card ul{grid-column:1;grid-row:auto}.report,.results,.saved,.workspace{width:min(100% - 28px,1180px)}.saved-item{grid-template-columns:64px minmax(0,1fr)}.saved-item button{grid-column:span 1}.hero{min-height:520px;padding:46px 14px}h1{font-size:34px}.image-stage{min-height:340px}}