*{box-sizing:border-box}html,body{height:100%}body{margin:0;background:radial-gradient(1200px 1200px at 70% -10%,#172038 0%,var(--bg) 60%);color:var(--text);font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Cantarell,Helvetica Neue,Arial,Noto Sans,"Apple Color Emoji","Segoe UI Emoji";overflow:hidden;-webkit-user-select:none;user-select:none}#root{height:100%}.app{display:grid;grid-template-columns:1fr 320px;grid-template-rows:auto 1fr;grid-template-areas:"toolbar toolbar" "stage sidebar";height:100vh;gap:10px;padding:12px;position:relative}.toolbar{grid-area:toolbar;background:linear-gradient(180deg,#ffffff0f,#ffffff05);border:1px solid rgba(255,255,255,.08);border-radius:var(--radius);padding:8px;display:flex;flex-direction:column;gap:12px;align-items:stretch;box-shadow:var(--shadow);position:relative}.toolbar-row{display:flex;flex-wrap:wrap;align-items:center;gap:12px}.toolbar-row-top{row-gap:10px}.toolbar-row-top .group{padding-right:10px;margin-right:10px}.toolbar-row-top .group:last-child{padding-right:0;margin-right:0}.toolbar-row-top .group-lang{margin-left:auto}.group-lang>.primary{margin-right:6px}.toolbar-row-meta{display:flex;flex-wrap:wrap;align-items:center;gap:12px}.meta-block{display:flex;flex-wrap:wrap;align-items:center;gap:8px}.meta-block.scale-block{flex:1 1 240px}.meta-block.mode-block{flex:1 1 180px}.meta-block.sensitivity-block{margin-left:auto;gap:10px}.meta-block.sensitivity-block input[type=range]{width:180px}.toolbar .group{display:flex;align-items:center;gap:8px;padding-right:12px;margin-right:12px;position:relative}.toolbar .group:last-child{padding-right:0;margin-right:0}.toolbar .group:not(:last-child):after{content:"";position:absolute;right:0;top:6px;bottom:6px;width:1px;background:linear-gradient(180deg,#ffffff29,#fff0);opacity:.45;border-radius:1px}button,.btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1px solid rgba(255,255,255,.12);background:#ffffff0a;color:var(--text);padding:6px 12px;height:36px;display:inline-flex;align-items:center;gap:6px;border-radius:10px;cursor:pointer;font-weight:600;font-size:15px;letter-spacing:.2px;transition:transform .06s ease,background .2s ease,border-color .2s ease,box-shadow .2s ease;box-shadow:0 1px #ffffff0d inset}button:hover,.btn:hover{background:#ffffff14}button:active,.btn:active{transform:translateY(1px) scale(.998)}button.primary{border-color:#6aa6ff59;background:linear-gradient(180deg,#6aa6ff40,#6aa6ff1f);color:var(--text)}button.warn{border-color:#ff6a7a59;background:linear-gradient(180deg,#ff6a7a40,#ffffff1f);color:var(--text)}button.ghost{background:transparent;color:var(--text)}.toggle[aria-pressed=true],.is-active{outline:2px solid var(--accent);background:#6aa6ff29}input[type=file]{display:none}label.file{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;height:36px;border:1px dashed rgba(255,255,255,.18);border-radius:10px;cursor:pointer;background:#ffffff08;font-size:15px}.stage{grid-area:stage;background:var(--panel);border:1px solid rgba(255,255,255,.08);border-radius:var(--radius);position:relative;overflow:hidden;box-shadow:var(--shadow);min-width:320px}canvas{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;display:block}.hud-tip{position:absolute;left:12px;bottom:12px;background:#0a0c12cc;border:1px solid rgba(255,255,255,.12);padding:8px 10px;border-radius:10px;font-size:12px;color:var(--muted);pointer-events:none;box-shadow:var(--shadow);transform:translateY(0);transition:transform .4s ease}.sidebar{grid-area:sidebar;background:linear-gradient(180deg,#ffffff0f,#ffffff05);border:1px solid rgba(255,255,255,.08);border-radius:var(--radius);padding:12px;box-shadow:var(--shadow);display:flex;flex-direction:column;overflow:hidden;height:100%}.sidebar-measurements{display:flex;flex-direction:column;flex:1 1 auto;min-height:0;overflow-y:auto;padding-bottom:8px}.measure-controls.slim{display:flex;gap:6px;margin-bottom:8px;padding:4px 8px}.measure-controls.slim button{min-width:32px;height:32px;padding:0 12px;font-size:15px;display:flex;align-items:center;justify-content:center}.sidebar-hints{margin-top:auto;align-self:flex-end;width:100%;flex-shrink:0}.sidebar:last-of-type{margin-bottom:0}.row{display:flex;justify-content:space-between;align-items:center;gap:8px;margin:6px 0}.badge{font-size:12px;background:#ffffff14;padding:2px 10px;min-height:28px;display:inline-flex;align-items:center;border-radius:999px;color:var(--muted);border:1px solid rgba(255,255,255,.1)}.info-card{background:#ffffff0d;border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:12px;margin-bottom:8px;display:grid;gap:6px}.info-card-title{font-weight:700;letter-spacing:.2px}.info-card-body{font-size:12px;color:var(--muted);line-height:1.45}.info-card-body .muted{color:inherit}.stats-card{background:#ffffff0d;border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:12px;margin-bottom:8px;display:grid;gap:4px}.stats-title{font-weight:700;letter-spacing:.2px}.stats-line{font-size:12px;color:var(--muted)}.stats-line-strong{color:var(--text);font-weight:600}.measure-controls{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:8px}.measure-list{margin-top:10px;display:flex;flex-direction:column;gap:8px;flex:1 1 auto;overflow-y:auto;min-height:0;padding-right:4px}.card{display:block;background:#ffffff0a;border-radius:8px;margin-bottom:8px;padding:6px 10px;box-shadow:0 1px 4px #0000000a}.card>div:first-child{flex:1 1 200px;min-width:0}.card .title{font-weight:700;letter-spacing:.2px;word-break:break-word}.card .muted{color:var(--muted);font-size:12px;word-break:break-word;white-space:normal}.card .actions{display:flex;gap:6px;flex-wrap:wrap;justify-content:flex-end}.measure-top-row{display:flex;align-items:center;gap:8px;font-size:18px;margin-bottom:2px}.measure-orient-icon{font-size:20px;margin-right:2px}.measure-index{font-weight:700;font-size:15px;color:var(--accent)}.measure-values-row{display:flex;gap:12px;font-size:14px;margin-bottom:6px;margin-top:2px}.measure-value-cm,.measure-value-px{background:#ffffff12;border-radius:4px;padding:2px 8px;font-weight:500}.actions.measure-actions-row{display:flex;gap:6px;margin-top:4px}.actions.measure-actions-row .icon-btn{width:32px;height:32px;font-size:18px;padding:0;border-radius:6px;background:#ffffff14;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s}.icon-btn{width:32px;height:32px;padding:0;border-radius:8px;background:#ffffff0f;border:1px solid rgba(255,255,255,.12);cursor:pointer;font-size:18px;display:inline-flex;align-items:center;justify-content:center;gap:4px}.icon-btn.danger{border-color:#ff6a7a66;color:var(--danger);background:#ff00001f;width:32px;height:32px}.kbd{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:12px;padding:2px 6px;border-radius:6px;background:#ffffff14;border:1px solid rgba(255,255,255,.12)}.lang-picker{position:relative}.lang-picker button{min-width:110px;justify-content:center}.lang-list{position:absolute;right:0;top:calc(100% + 6px);background:#0a0c12f0;border:1px solid rgba(255,255,255,.16);border-radius:10px;padding:6px;display:none;flex-direction:column;gap:4px;box-shadow:var(--shadow);z-index:20}.lang-picker.open .lang-list{display:flex}.lang-option{background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:8px;padding:6px 10px;display:flex;gap:8px;align-items:center;cursor:pointer}.lang-option:hover{background:#ffffff14}.modal{position:fixed;top:0;right:0;bottom:0;left:0;background:#03060ca6;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .2s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);padding:20px;z-index:40}.modal.show{opacity:1;pointer-events:auto}.modal .panel{background:linear-gradient(180deg,#ffffff14,#ffffff05);border:1px solid rgba(255,255,255,.12);border-radius:16px;padding:18px;box-shadow:var(--shadow);min-width:320px}.modal h3{margin:0 0 8px}.modal p{margin:0 0 16px;color:var(--muted);font-size:14px;line-height:1.4}.modal input[type=number]{width:140px;padding:6px 10px;border-radius:10px;border:1px solid rgba(255,255,255,.16);background:#0a0c12a6;color:var(--text);font-size:14px}.range-wrap{display:inline-flex;align-items:center;gap:8px}.range-wrap input[type=range]{width:120px}.badge.accent{border-color:#87ffb066;color:var(--accent-2)}.measure-empty{color:var(--muted);font-size:13px;padding:16px 8px;text-align:center}.card.hidden .title{color:var(--muted)}.group.group-rounding{display:flex;align-items:center;gap:8px;background:#ffffff0a;border-radius:10px;padding:4px 16px;border:1px solid rgba(255,255,255,.1);box-shadow:0 1px 4px #0000000a}.group.group-rounding label{color:var(--muted);font-size:14px;font-weight:500;margin-right:6px}.group.group-rounding select{background:#172038;color:#e8ecf1;border:1px solid var(--accent);border-radius:8px;padding:7px 22px 7px 12px;font-size:15px;font-weight:600;outline:none;box-shadow:0 1px #ffffff0d inset;transition:border-color .2s,background .2s;margin-left:2px;margin-right:5px}.group.group-rounding select:focus{border-color:var(--accent-2);background:#111521;color:#fff}@media (max-width: 1040px){.app{grid-template-columns:1fr;grid-template-rows:auto minmax(300px,1fr) 240px 120px;grid-template-areas:"toolbar" "stage" "sidebar" "sidebar"}.sidebar{max-height:240px}.sidebar[aria-label="Usage tips sidebar"]{max-height:120px}}.measure-main-row.compact{display:flex;align-items:center;justify-content:space-between;min-height:36px}.measure-actions-right{display:flex;flex-direction:row;gap:6px;flex-shrink:0;flex-wrap:nowrap;align-items:center}.mobile-blocker{position:relative;overflow:hidden;max-width:560px;width:min(92vw,560px);text-align:center}.mobile-blocker .mb-head h3{margin:6px 0 8px;font-size:clamp(20px,3.6vw,26px);letter-spacing:.2px}.mobile-blocker .mb-head .mb-lead{margin:0 auto 12px;color:var(--muted);font-size:15px;line-height:1.45}.mobile-blocker .mb-icon{width:86px;height:86px;display:grid;place-items:center;margin:2px auto 8px;font-size:42px;border-radius:24px;background:linear-gradient(180deg,#6aa6ff40,#87ffb02e);border:1px solid rgba(255,255,255,.14);box-shadow:var(--shadow)}.mobile-blocker .mb-actions{display:flex;gap:10px;justify-content:center;margin:12px 0 6px}.mobile-blocker .btn.btn-xl{height:46px;padding:10px 16px;font-size:15px;border-radius:12px}.mobile-blocker .btn.primary{border-color:#6aa6ff8c;background:linear-gradient(180deg,#6aa6ff6b,#6aa6ff2e);box-shadow:0 8px 28px #6aa6ff2e}.mobile-blocker .mb-hint{margin:10px auto 0;color:var(--muted);font-size:13px}.mobile-blocker .mb-hint .badge{margin-right:8px}.mobile-blocker .mb-foot{margin-top:14px;color:var(--muted);font-size:12px}.mb-glow{position:absolute;filter:blur(48px);opacity:.6;pointer-events:none}.mb-glow-a{width:360px;height:360px;background:radial-gradient(closest-side,var(--accent),transparent 70%);right:-120px;top:-120px}.mb-glow-b{width:380px;height:380px;background:radial-gradient(closest-side,var(--accent-2),transparent 70%);left:-140px;bottom:-140px}@media (max-width: 900px){body{overflow:hidden!important}}:root{--bg: #0b0e14;--panel: #111521;--accent: #6aa6ff;--accent-2: #87ffb0;--muted: #8b98a5;--text: #e8ecf1;--danger: #ff6a7a;--shadow: 0 6px 24px rgba(0,0,0,.35);--radius: 14px}.landing-nav{display:flex;align-items:center;gap:14px;background:linear-gradient(180deg,#ffffff0f,#ffffff05);border:1px solid rgba(255,255,255,.08);border-radius:var(--radius);padding:10px 14px;box-shadow:var(--shadow)}.brand{display:inline-flex;align-items:center;gap:10px;font-weight:800;letter-spacing:.2px;color:var(--text);text-decoration:none;font-size:18px}.brand-dot{width:10px;height:10px;border-radius:50%;background:linear-gradient(180deg,var(--accent),var(--accent-2));box-shadow:0 0 24px #6aa6ff73}.landing-nav .links{display:flex;gap:16px;margin-left:6px}.landing-nav .links a{color:var(--muted);text-decoration:none;font-weight:600;font-size:14px}.landing-nav .links a:hover{color:var(--text)}.landing-nav .btn.cta{margin-left:auto;border-color:#6aa6ff73;background:linear-gradient(180deg,#6aa6ff59,#6aa6ff24);height:40px;padding:8px 16px}.hero{position:relative;display:grid;grid-template-columns:1.1fr .9fr;gap:24px;align-items:center}.hero-copy h1{margin:0 0 12px;font-size:clamp(28px,5vw,46px);line-height:1.08;letter-spacing:.2px}.hero-copy .lead{margin:0 0 18px;color:var(--muted);font-size:clamp(15px,2.3vw,18px)}.cta-row{display:flex;gap:12px;align-items:center;margin:18px 0 10px}.btn.btn-xl{height:48px;padding:10px 18px;font-size:16px;border-radius:12px}.btn.primary{border-color:#6aa6ff8c;background:linear-gradient(180deg,#6aa6ff6b,#6aa6ff2e);box-shadow:0 8px 28px #6aa6ff2e}.btn.primary:hover{filter:brightness(1.06)}.btn.ghost{background:#ffffff0a}.trust{display:flex;gap:10px;align-items:center;margin-top:10px}.hero-art{position:relative;min-height:340px;background:var(--panel);border:1px solid rgba(255,255,255,.08);border-radius:16px;box-shadow:var(--shadow);overflow:hidden}.glow{position:absolute;filter:blur(40px);opacity:.55}.glow-a{width:320px;height:320px;background:radial-gradient(closest-side,var(--accent),transparent 70%);right:-60px;top:-60px}.glow-b{width:360px;height:360px;background:radial-gradient(closest-side,var(--accent-2),transparent 70%);left:-80px;bottom:-80px}.grid-hint,.grid-hint.second{position:absolute;background:#0a0c12cc;border:1px solid rgba(255,255,255,.12);padding:6px 10px;border-radius:10px;font-size:12px;color:var(--muted);box-shadow:var(--shadow)}.grid-hint{left:14px;top:14px}.grid-hint.second{right:14px;bottom:14px}.how .steps{display:grid;gap:10px;grid-template-columns:repeat(3,1fr);margin:0;padding:0;list-style:none}.step-num{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;background:#ffffff0f;border:1px solid rgba(255,255,255,.12);margin-right:8px;font-weight:700;color:var(--accent)}body.landing-mode{overflow:auto}.landing{min-height:100vh;padding:20px 20px 60px;display:grid;grid-template-rows:auto 1fr auto;gap:28px}.features{margin-top:8px}.features h2,.how h2,.faq h2{margin:0 0 14px;font-size:22px}.cards{display:grid;gap:12px;grid-template-columns:repeat(4,1fr)}.cards .card{background:#ffffff0d;border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:14px}.feature{display:grid;grid-template-columns:44px 1fr;gap:12px;align-items:start}.feature .icon{width:44px;height:44px;border-radius:12px;display:grid;place-items:center;background:linear-gradient(180deg,#6aa6ff38,#87ffb01a);border:1px solid rgba(255,255,255,.1);color:var(--text);box-shadow:var(--shadow)}.card-title{font-weight:700;margin:0 0 6px}.card-body{color:var(--muted);font-size:14px;line-height:1.45}.how .steps-rail:before{content:"";position:absolute;left:22px;top:0;bottom:0;width:2px;background:linear-gradient(180deg,#ffffff2e,#ffffff0a);border-radius:2px}.step{position:relative;display:grid;grid-template-columns:44px 1fr;gap:12px;align-items:start;background:#ffffff0d;border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:12px}.step-badge{z-index:1;display:grid;place-items:center;width:44px;height:44px;border-radius:12px;background:linear-gradient(180deg,#6aa6ff59,#6aa6ff24);border:1px solid rgba(106,166,255,.45);font-weight:800;color:#fff;text-shadow:0 1px 0 rgba(0,0,0,.25);box-shadow:0 10px 30px #6aa6ff26}.step-title{font-weight:700;margin:2px 0 4px;letter-spacing:.2px}.step-text{color:var(--muted);font-size:14px;line-height:1.45}.faq .faq-item{background:#ffffff0d;border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:10px 12px;margin-bottom:8px}.faq summary{cursor:pointer;font-weight:700}.faq p{color:var(--muted);margin:6px 0 0}.landing-foot{display:flex;gap:12px;align-items:center;justify-content:space-between;color:var(--muted);border-top:1px solid rgba(255,255,255,.08);padding-top:14px}@media (max-width: 1100px){.hero{grid-template-columns:1fr}.cards{grid-template-columns:repeat(2,1fr)}}@media (max-width: 640px){.cards{grid-template-columns:1fr}}.hero-art{position:relative;overflow:hidden}.hero-img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:contain;opacity:.99;mix-blend-mode:screen;pointer-events:none;filter:saturate(1.05) contrast(1.05) brightness(.95);border-radius:16px}
