:root{--bg: radial-gradient(1200px 600px at 10% -10%, #0e1220 0%, #0b0f1a 35%, #0a0d16 100%);--panel: #121626;--panel-elev: #161b2e;--text: #e6e6e6;--muted: #a1a8b3;--accent: #7aa2ff;--accent-2: #ff7a90;--grid-border: #242a38;--shadow-1: 0 4px 16px rgba(0,0,0,.35), inset 0 1px 0 rgba(255,255,255,.02);--shadow-2: 0 10px 30px rgba(0,0,0,.45), 0 2px 10px rgba(0,0,0,.25);--control-bg: #0f1320;--canvas-bg: #0b0f1a}[data-theme=light]{--bg: radial-gradient(1200px 600px at 10% -10%, #f4f7ff 0%, #f0f4fb 35%, #edf2f9 100%);--panel: #ffffff;--panel-elev: #f8fbff;--text: #0b0f1a;--muted: #5f6b7c;--accent: #3b63ff;--accent-2: #ff6a7f;--grid-border: #d9dee7;--shadow-1: 0 1px 2px rgba(0,0,0,.06), 0 1px 1px rgba(0,0,0,.03);--shadow-2: 0 10px 30px rgba(0,0,0,.15), 0 2px 10px rgba(0,0,0,.08);--control-bg: #f4f7ff;--canvas-bg: #ffffff}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;background:#0b0f1a;background-image:var(--bg);color:var(--text);font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,"Apple Color Emoji","Segoe UI Emoji"}@media (max-width: 900px){.app{grid-template-columns:1fr;grid-template-rows:auto auto 1fr auto;grid-template-areas:"header" "main" "sidebar" "footer"}.main{order:2;min-height:66vh}.sidebar{order:3;max-height:34vh;overflow:auto;border-right:none;border-top:1px solid var(--grid-border)}.header{position:sticky;top:0;z-index:10}.toolbar{flex-wrap:nowrap;overflow-x:auto}}@media (hover: none) and (pointer: coarse){.app{grid-template-columns:1fr;grid-template-rows:auto auto 1fr auto;grid-template-areas:"header" "main" "sidebar" "footer"}.main{min-height:66vh}.sidebar{max-height:34vh;overflow:auto;border-right:none;border-top:1px solid var(--grid-border)}.header{position:sticky;top:0;z-index:10}.toolbar{flex-wrap:nowrap;overflow-x:auto}}@media (max-width: 600px){.modal-overlay{padding:8px}.modal{border-radius:8px;padding:10px}.minimap{width:140px;height:96px}}.app{display:grid;grid-template-columns:320px 1fr;grid-template-rows:auto 1fr auto;grid-template-areas:"header header" "sidebar main" "footer footer";height:100%}.header{grid-area:header;padding:12px 16px;border-bottom:1px solid var(--grid-border);display:flex;align-items:center;gap:12px;background:linear-gradient(180deg,#ffffff0a,#fff0);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.app-logo{width:32px;height:32px;border-radius:8px;box-shadow:var(--shadow-1)}.sidebar{grid-area:sidebar;padding:12px;border-right:1px solid var(--grid-border);overflow:auto;background:linear-gradient(180deg,#ffffff0a,#ffffff05)}.main{grid-area:main;padding:0;display:grid;grid-template-rows:auto 1fr;min-width:0}.toolbar{padding:8px 12px;border-bottom:1px solid var(--grid-border);background:linear-gradient(180deg,#ffffff0f,#ffffff05);display:flex;gap:8px;flex-wrap:wrap;align-items:center}.footer{grid-area:footer;padding:10px 16px;border-top:1px solid var(--grid-border);background:linear-gradient(180deg,#ffffff05,#ffffff0a);color:var(--muted);font-size:12px;text-align:center}.canvas-wrap{position:relative;overflow:hidden}.controls-group{border:1px solid var(--grid-border);border-radius:12px;padding:12px;margin-bottom:12px;background:var(--panel);box-shadow:var(--shadow-1)}.controls-group h3{margin:0 0 8px;font-size:14px;color:var(--muted);font-weight:600}.label-row{display:grid;grid-template-columns:1fr auto;gap:8px;align-items:center;margin:6px 0}input[type=range],input[type=number],select,button,input[type=text],input[type=color]{background:var(--control-bg);color:var(--text);border:1px solid var(--grid-border);border-radius:10px;padding:8px 10px;box-shadow:var(--shadow-1)}button{cursor:pointer;transition:transform .05s ease}button:active{transform:translateY(1px)}button.primary{background:linear-gradient(180deg,#8ab3ff,#6a93ff);color:#0a0f1a;border:none}button.warn{background:linear-gradient(180deg,#ff9aa7,#ff7a90);color:#0a0f1a;border:none}.palette{display:flex;gap:8px;flex-wrap:wrap}.color-swatch{width:28px;height:28px;border-radius:8px;border:1px solid var(--grid-border);display:inline-flex;align-items:center;justify-content:center;font-size:12px;box-shadow:var(--shadow-1)}.grid-canvas,.mask-canvas,.row-overlay{image-rendering:pixelated}.row-instructions{font-size:24px;font-weight:800}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000c;display:flex;align-items:stretch;justify-content:stretch;padding:24px;overflow:hidden}.modal{width:100%;height:100%;overflow:hidden;background:linear-gradient(180deg,#ffffff0a,#ffffff05);border:1px solid var(--grid-border);border-radius:12px;padding:16px;box-shadow:var(--shadow-2)}.modal.landing{display:grid;grid-template-rows:auto 1fr;gap:12px}.landing-header{display:flex;align-items:center;gap:12px}.landing-content{display:grid;grid-template-columns:1fr 360px;gap:16px;min-height:0}@media (max-width: 900px),(hover: none) and (pointer: coarse){.landing-content{grid-template-columns:1fr}}.landing-section{background:var(--panel);border:1px solid var(--grid-border);border-radius:12px;padding:12px;box-shadow:var(--shadow-1);display:flex;flex-direction:column;min-height:0}.landing-section .section-title{font-weight:700;color:var(--muted);margin-bottom:8px}.empty-state{color:var(--muted);font-size:14px}.recent-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:12px;overflow:auto;padding:4px}.recent-card{background:#0f1320;border:1px solid var(--grid-border);border-radius:12px;padding:0;text-align:left;box-shadow:var(--shadow-1)}.recent-card:hover{border-color:#7aa2ff73}.card-inner{display:grid;grid-template-rows:180px auto}.preview-canvas{width:100%;height:180px;display:block;background:var(--canvas-bg);border-bottom:1px solid var(--grid-border)}.card-meta{padding:10px;display:grid;gap:4px}.card-title{font-weight:700}.card-sub{color:var(--muted);font-size:12px}.progress-row{display:grid;grid-template-columns:1fr auto;gap:8px;align-items:center}.progress-bar{height:8px;background:#0b0f1a;border:1px solid var(--grid-border);border-radius:999px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(180deg,#8ab3ff,#6a93ff)}.new-project{display:grid;gap:8px}.new-project-card{display:flex;gap:12px;align-items:center;padding:12px;background:var(--panel);border:1px solid var(--grid-border);border-radius:12px;box-shadow:var(--shadow-1)}.new-project-visual{width:80px;height:80px;display:grid;place-items:center;background:var(--panel-elev);border-radius:12px;color:var(--accent);border:1px solid var(--grid-border)}.np-title{font-weight:700}.np-sub{color:var(--muted);font-size:12px}.crochet-layout{display:grid;grid-template-rows:auto auto 1fr;gap:12px;height:100%;min-height:0;background:var(--panel)}.crochet-top{display:flex;align-items:center;gap:12px}.crochet-row-info{font-size:14px;color:var(--muted)}.crochet-canvas-wrap{position:relative;width:100%;height:100%;overflow:hidden}.crochet-canvas{position:absolute;top:0;right:0;bottom:0;left:0;image-rendering:pixelated;width:100%;height:100%;background:var(--canvas-bg);border:1px solid var(--grid-border);border-radius:8px}.minimap{position:absolute;right:12px;bottom:12px;width:180px;height:120px;border-radius:8px;overflow:hidden;border:1px solid var(--grid-border);box-shadow:var(--shadow-2);background:#0a0e18aa;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.minimap-canvas{width:100%;height:100%;image-rendering:pixelated;display:block}.crochet-layout,.crochet-top,.crochet-row-info,.row-instructions{contain:layout style paint}.row-tape-wrap{position:relative;padding-bottom:36px;overflow:hidden}.row-visual{display:block;width:100%;overflow-x:auto;white-space:nowrap;padding-bottom:8px;max-width:100%;margin-top:12px}.row-spacer{display:inline-block;height:18px}.row-tape-wrap{position:relative;padding-bottom:36px}.row-cell{display:inline-block;width:18px;height:18px;border:1px solid var(--grid-border);border-radius:4px;position:relative;margin-right:3px}.row-cell.current{outline:2px solid #fff;box-shadow:0 0 0 3px #000000e6 inset,0 0 0 1px #ffffffe6 inset}.runs-overlay{position:absolute;left:0;right:0;bottom:0;height:32px;pointer-events:none;will-change:transform;z-index:2}.run-box{position:absolute;bottom:6px;height:20px;display:flex;align-items:center;justify-content:center}.run-line{position:relative;width:100%;height:8px}.run-line:before,.run-line:after{content:"";position:absolute;top:50%;height:6px;transform:translateY(-50%);background:linear-gradient(180deg,#7aa2ff40,#7aa2ff26);border:1px solid rgba(122,162,255,.4);border-radius:999px;box-shadow:0 4px 12px #00000040 inset}.run-line:before{left:0;right:0}.run-line span{position:absolute;left:50%;transform:translate(-50%,-50%);top:50%;padding:0 8px;color:#d7e3ff;font-weight:700;font-size:14px;line-height:1;background:#0a0f1ad9;border:1px solid rgba(122,162,255,.35);border-radius:999px;box-shadow:0 1px 2px #0009}.tool-row{display:inline-flex;gap:6px;background:var(--control-bg);padding:6px;border-radius:12px;border:1px solid var(--grid-border);box-shadow:var(--shadow-1)}.tool-btn{width:34px;height:34px;display:inline-flex;align-items:center;justify-content:center;border-radius:10px;border:1px solid transparent;background:transparent;color:var(--text)}.tool-btn:hover{background:#ffffff0f}.tool-btn.active{background:#7aa2ff2e;border-color:#7aa2ff73}.brush-overlay{pointer-events:none;outline:2px dashed rgba(255,255,255,.8);border-radius:6px;box-shadow:0 0 0 2px #00000040 inset}@media (max-width: 900px),(hover: none) and (pointer: coarse){.app{grid-template-columns:1fr!important;grid-template-rows:auto 1fr auto auto!important;grid-template-areas:"header" "main" "sidebar" "footer"!important}.landing-content{grid-template-columns:1fr!important}.main{min-height:66vh}.sidebar{max-height:34vh;overflow:auto;border-right:none;border-top:1px solid var(--grid-border)}}
