@import"https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,600;9..144,700&family=Space+Grotesk:wght@400;500;600;700&display=swap";.brand-lockup{display:inline-flex;align-items:center;gap:.42em}.brand-mark{--brand-mark-size: 1em;position:relative;display:inline-block;width:var(--brand-mark-size);height:var(--brand-mark-size);flex:0 0 auto}.brand-mark-core{position:absolute;inset:35%;border-radius:50%;background:linear-gradient(140deg,var(--accent-cyan-strong),#ffad5b);box-shadow:0 0 0 1px #ffffffbf}.brand-mark-orbit{position:absolute;inset:7%;border-radius:50%;border:1.5px solid rgba(5,78,108,.46)}.brand-mark-orbit-a{transform:rotate(26deg) scaleY(.62)}.brand-mark-orbit-b{transform:rotate(-26deg) scaleX(.62);border-color:#f7912975}.app-header{position:sticky;top:0;z-index:10;display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:.85rem clamp(1rem,2.8vw,2rem);border-bottom:1px solid rgba(255,255,255,.55);background:linear-gradient(135deg,#fcffffdb,#f4fbffc7 52%,#fff6ecd6);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);box-shadow:0 10px 24px #0a27421f}.header-left{display:flex;align-items:center;gap:1.5rem;min-width:0}.header-left nav{display:flex;gap:.45rem;flex-wrap:wrap}.header-left nav a{color:var(--ink-700);text-decoration:none;font-size:.84rem;font-weight:600;padding:.35rem .68rem;border-radius:999px;transition:color .18s ease,background .18s ease}.header-left nav a:hover{color:var(--accent-cyan-strong);background:#1188a11a}.logo{display:inline-flex;align-items:center;font-family:Fraunces,Georgia,serif;font-weight:700;font-size:1.28rem;line-height:1;color:var(--ink-900);text-decoration:none}.logo .brand-mark{--brand-mark-size: .92em}.logo:hover{color:var(--accent-cyan-strong)}.header-right{display:flex;align-items:center}.auth-panel{flex-direction:column;align-items:flex-end;gap:.35rem}.user-info{display:flex;align-items:center;gap:.55rem}.avatar{width:30px;height:30px;border-radius:50%;border:1px solid rgba(255,255,255,.9);box-shadow:0 4px 10px #0e2e4c2e}.username{font-size:.84rem;font-weight:600;color:var(--ink-700);max-width:12rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.auth-error{margin:0;max-width:300px;font-size:.74rem;color:#b42318;text-align:right}@media(max-width:760px){.app-header{flex-wrap:wrap;justify-content:center;padding-top:.75rem;padding-bottom:.75rem}.header-left{width:100%;justify-content:space-between}.auth-panel{width:100%;align-items:center}.auth-error{text-align:center}}.shader-backdrop{position:fixed;inset:0;pointer-events:none;z-index:0;overflow:hidden}.shader-backdrop-canvas{width:100%;height:100%;display:block;filter:saturate(94%) contrast(100%);opacity:.55}.shader-backdrop-vignette{position:absolute;inset:-20%;background:radial-gradient(circle at 12% 12%,rgba(255,249,238,.42),transparent 48%),radial-gradient(circle at 84% 14%,rgba(180,230,234,.24),transparent 54%),radial-gradient(circle at 50% 74%,rgba(240,177,112,.2),transparent 60%);mix-blend-mode:soft-light;opacity:.5}.shader-backdrop-haze{position:absolute;inset:0;background:linear-gradient(150deg,#faffff85,#f0f8ff38 42%,#fff6ea7a),repeating-linear-gradient(120deg,rgba(255,255,255,.025) 0px,rgba(255,255,255,.025) 1px,transparent 1px,transparent 14px);opacity:.3}@media(prefers-reduced-motion:reduce){.shader-backdrop-canvas{filter:saturate(92%) contrast(100%)}}.app-layout{min-height:100vh;display:flex;flex-direction:column;position:relative;isolation:isolate}.app-layout>:not(.shader-backdrop){position:relative;z-index:1}.app-main{flex:1;padding:clamp(1rem,2.5vw,2rem);max-width:1200px;margin:0 auto;width:100%;box-sizing:border-box}.game-canvas-shell{position:relative;display:inline-block;padding:.75rem;border-radius:20px;background:linear-gradient(155deg,#feffffd6,#f3faffc2 48%,#fff5ebd1);border:1px solid rgba(255,255,255,.72);box-shadow:0 18px 36px #122e4933,inset 0 1px #ffffffb3;overflow:hidden}.game-canvas{position:relative;z-index:1;display:block;max-width:100%;border-radius:12px;border:1px solid rgba(20,54,78,.16);background:#eef5fb;image-rendering:pixelated}.game-canvas-shine{position:absolute;inset:0;pointer-events:none;background:radial-gradient(circle at 18% 14%,rgba(255,255,255,.55),transparent 35%),linear-gradient(125deg,transparent 45%,rgba(255,255,255,.24) 50%,transparent 58%);mix-blend-mode:screen;opacity:.82;animation:canvas-sheen 6s ease-in-out infinite alternate}@keyframes canvas-sheen{0%{transform:translate(-4%);opacity:.72}to{transform:translate(4%);opacity:.9}}@media(max-width:640px){.game-canvas-shell{display:block;width:100%;padding:.5rem;margin:0 auto}.game-canvas{width:100%;height:auto}}.home-page{display:grid;gap:1.6rem;animation:page-rise .44s ease-out both}.hero{text-align:center;margin:0 auto;width:min(760px,100%);padding:clamp(1.2rem,3vw,2rem);border-radius:var(--radius-card);border:1px solid var(--surface-border);background:linear-gradient(165deg,#ffffffd1,#f3fbffc7 58%,#fff5e9d1);box-shadow:var(--shadow-soft)}.hero h1{font-size:clamp(2.1rem,5vw,3.3rem);margin-bottom:.65rem}.hero h1 .brand-lockup{gap:.28em}.hero h1 .brand-mark{--brand-mark-size: .72em}.hero p{max-width:620px;margin:0 auto;font-size:1rem}.featured-level{margin:0 auto;width:min(920px,100%);padding:clamp(1rem,2.6vw,1.5rem);border-radius:var(--radius-card);border:1px solid var(--surface-border);background:var(--surface-card);box-shadow:var(--shadow-strong)}.featured-level h2{text-align:center;font-size:clamp(1.35rem,2.2vw,1.65rem);margin-bottom:.85rem}.home-page .game-area{display:flex;flex-direction:column;align-items:center;gap:1rem}.home-page .controls{width:min(620px,100%);display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:.9rem 1rem;border-radius:16px;border:1px solid rgba(255,255,255,.72);background:#ffffffa3;box-shadow:0 12px 24px #0c253c1a}.home-page .control-buttons{display:flex;gap:.5rem;flex-wrap:wrap;justify-content:center}.home-page .speed-control{font-size:.84rem;color:var(--ink-500)}.home-page .speed-control input[type=range]{width:160px;vertical-align:middle}.home-page .win-message{padding:.65rem 1rem;border-radius:999px;font-weight:600;color:#854513;border:1px solid rgba(223,164,73,.62);background:linear-gradient(130deg,#fff3d2e6,#ffe9b5d6)}.links{display:flex;justify-content:center;gap:.75rem;flex-wrap:wrap;margin-top:.2rem}.links .btn{min-width:10.5rem}@media(max-width:640px){.featured-level,.hero{padding:1rem}.home-page .controls{padding:.75rem}.home-page .control-buttons{width:100%}}.about-page{display:grid;gap:1.6rem;animation:page-rise .44s ease-out both;max-width:920px;margin:0 auto;padding:0 1rem 2rem}.about-hero{text-align:center;margin:0 auto;width:100%;padding:clamp(1.2rem,3vw,2rem);border-radius:var(--radius-card);border:1px solid var(--surface-border);background:linear-gradient(165deg,#ffffffd1,#f3fbffc7 58%,#fff5e9d1);box-shadow:var(--shadow-soft)}.about-hero h1{font-size:clamp(2.1rem,5vw,3rem);margin-bottom:0}.about-hero h1 .brand-lockup{gap:.28em}.about-hero h1 .brand-mark{--brand-mark-size: .72em}.about-content{padding:clamp(1.5rem,3vw,2.5rem);border-radius:var(--radius-card);border:1px solid var(--surface-border);background:var(--surface-card);box-shadow:var(--shadow-strong)}.about-section{margin-bottom:2.5rem}.about-section:last-of-type{margin-bottom:2rem}.about-section h2{font-size:clamp(1.5rem,2.5vw,1.85rem);margin-bottom:1rem;color:var(--ink-900)}.about-section h3{font-size:clamp(1.15rem,2vw,1.35rem);margin-bottom:.5rem;margin-top:.75rem;color:var(--ink-800)}.about-section p{margin-bottom:1rem;line-height:1.7;color:var(--ink-700)}.about-section ol,.about-section ul{margin-bottom:1rem;padding-left:1.5rem}.about-section li{margin-bottom:.5rem;line-height:1.6;color:var(--ink-700)}.about-section ol li{padding-left:.25rem}.about-section strong{font-weight:600;color:var(--ink-800)}.pattern-list{display:grid;gap:1.5rem;margin-top:1.25rem}.pattern-item{padding:1.25rem;border-radius:12px;border:1px solid rgba(17,136,161,.15);background:#f0faff66}.pattern-item h3{margin-top:0}.pattern-item p{margin-bottom:.75rem}.pattern-item ul{margin-bottom:0}.pattern-shape-item{margin-bottom:.75rem}.pattern-shape-item:last-child{margin-bottom:0}.pattern-shape-entry{display:grid;grid-template-columns:auto 1fr;align-items:start;gap:.85rem}.pattern-visual{display:inline-flex;flex-shrink:0;padding:.45rem;border-radius:10px;border:1px solid rgba(17,136,161,.2);background:linear-gradient(180deg,#fffffff0,#e4f5fccc);box-shadow:inset 0 1px #ffffffb3}.pattern-grid{--pattern-cols: 3;--pattern-rows: 3;--cell-size: clamp(.36rem, .8vw, .55rem);display:grid;grid-template-columns:repeat(var(--pattern-cols),var(--cell-size));grid-template-rows:repeat(var(--pattern-rows),var(--cell-size));gap:2px}.pattern-cell{width:var(--cell-size);height:var(--cell-size);border-radius:2px;background:#1188a121}.pattern-cell.is-alive{background:linear-gradient(145deg,#43cbe2,#1188a1);box-shadow:inset 0 0 0 1px #ffffff59}.about-links{display:flex;justify-content:center;gap:.75rem;flex-wrap:wrap;margin-top:2rem;padding-top:2rem;border-top:1px solid rgba(17,136,161,.15)}.about-links .btn{min-width:10.5rem}@media(max-width:640px){.about-page{padding:0 .75rem 1.5rem}.about-hero{padding:1rem}.about-content{padding:1.25rem}.about-section{margin-bottom:2rem}.pattern-item{padding:1rem}.pattern-shape-entry{grid-template-columns:1fr;gap:.55rem}.pattern-grid{--cell-size: .46rem}}.levels-page{animation:page-rise .42s ease-out both}.levels-page h1{margin-bottom:.9rem;text-align:center;font-size:clamp(1.8rem,2.9vw,2.2rem)}.levels-toolbar{display:grid;grid-template-columns:1fr auto;gap:.7rem;margin:0 auto 1.2rem;max-width:920px;padding:.75rem;border-radius:16px;border:1px solid var(--surface-border);background:#ffffffad;box-shadow:var(--shadow-soft)}.search-input{width:100%;padding:.6rem .8rem;font-size:.9rem}.sort-select{padding:.6rem .8rem;min-width:180px;font-size:.88rem;background-color:#ffffffe6}.status{text-align:center;color:var(--ink-500);padding:1.5rem}.status.error{color:#b42318}.levels-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1rem}.level-card{border:1px solid var(--surface-border);border-radius:18px;background:#ffffffc7;box-shadow:var(--shadow-soft);overflow:hidden;transform:translateY(0);transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease;animation:level-card-rise .42s ease-out both}.level-card:nth-child(2n){animation-delay:40ms}.level-card:nth-child(3n){animation-delay:80ms}.level-card:hover{transform:translateY(-3px);border-color:#12738b59;box-shadow:0 18px 34px #0c2a4429}.level-card-link{display:block;padding:1rem;text-decoration:none;color:inherit}.level-card h3{margin:0 0 .3rem;font-size:1.1rem}.level-meta{font-size:.78rem;color:var(--ink-500);margin:0 0 .5rem}.level-desc{font-size:.84rem;color:var(--ink-700);margin:0 0 .6rem;line-height:1.4}.level-stats{display:flex;gap:.8rem;font-size:.8rem;color:var(--ink-500);margin-bottom:.25rem}.level-author{font-size:.74rem;color:#6f8199;margin:0}.level-high-scores{margin:.5rem 0 .4rem;padding:.45rem .5rem;border-radius:8px;background:#12738b12;border:1px solid rgba(18,115,139,.14)}.level-high-scores-title{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--ink-500);margin:0 0 .3rem}.level-hs-row{display:flex;align-items:center;gap:.3rem;font-size:.78rem;line-height:1.4}.level-hs-label{flex-shrink:0}.level-hs-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;color:var(--ink-700)}.level-hs-value{flex-shrink:0;color:var(--ink-500);font-size:.74rem}.level-card-actions{display:flex;gap:.4rem;padding:0 1rem 1rem}@keyframes level-card-rise{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media(max-width:680px){.levels-toolbar{grid-template-columns:1fr;padding:.65rem}.sort-select{width:100%}}.play-level-page{display:grid;justify-items:center;gap:1.25rem;animation:page-rise .42s ease-out both}.level-header{width:min(920px,100%);text-align:center;margin-bottom:.15rem;padding:clamp(1rem,2.8vw,1.5rem);border-radius:var(--radius-card);border:1px solid var(--surface-border);background:var(--surface-card);box-shadow:var(--shadow-soft)}.level-header h1{margin-bottom:.35rem;font-size:clamp(1.7rem,3vw,2.25rem)}.level-header p{margin:0 auto .75rem;max-width:700px}.level-header-actions{display:flex;gap:.5rem;justify-content:center;flex-wrap:wrap}.play-level-page .game-area{width:min(980px,100%);display:flex;flex-direction:column;align-items:center;gap:1rem;padding:clamp(1rem,2.6vw,1.5rem);border-radius:var(--radius-card);border:1px solid var(--surface-border);background:var(--surface-card-strong);box-shadow:var(--shadow-strong)}.play-level-page .controls{width:min(620px,100%);display:flex;flex-direction:column;align-items:center;gap:.75rem}.play-level-page .control-buttons{display:flex;gap:.5rem;flex-wrap:wrap;justify-content:center}.play-level-page .speed-control{font-size:.84rem;color:var(--ink-500)}.play-level-page .speed-control input[type=range]{width:180px;vertical-align:middle}.play-level-page .win-message{padding:.65rem 1rem;border-radius:999px;font-weight:600;color:#7c4213;border:1px solid rgba(225,166,77,.64);background:linear-gradient(125deg,#fff6d4eb,#ffebb6db)}.play-level-page .ended-message{padding:.65rem 1rem;border-radius:999px;font-weight:600;color:#6b1d1d;border:1px solid rgba(220,120,120,.64);background:linear-gradient(125deg,#ffdcdceb,#ffc8c8db)}@media(max-width:640px){.level-header,.play-level-page .game-area{padding:.95rem}}.high-scores{width:min(920px,100%);padding:clamp(1rem,2.8vw,1.5rem);border-radius:var(--radius-card);border:1px solid var(--surface-border);background:var(--surface-card);box-shadow:var(--shadow-soft)}.high-scores h2{text-align:center;margin-bottom:1rem;font-size:clamp(1.2rem,2vw,1.5rem)}.high-scores-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1.5rem}@media(max-width:860px){.high-scores-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:520px){.high-scores-grid{grid-template-columns:1fr}}.high-scores-col h3{font-size:1rem;margin-bottom:.5rem;text-align:center}.high-scores-col ol{list-style:none;padding:0;margin:0}.high-scores-col li{display:flex;justify-content:space-between;align-items:center;gap:.4rem;padding:.35rem .5rem;border-bottom:1px solid var(--surface-border);font-size:.9rem}.hs-rank{flex-shrink:0;color:var(--ink-500);min-width:1.4rem}.high-scores-col li:last-child{border-bottom:none}.hs-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:70%}.hs-value{font-weight:600;flex-shrink:0}.editor-page{display:grid;gap:1rem;animation:page-rise .42s ease-out both}.editor-page h1{margin-bottom:.2rem;text-align:center;font-size:clamp(1.8rem,3vw,2.2rem)}.editor-layout{display:grid;grid-template-columns:minmax(300px,360px) 1fr;gap:1rem;align-items:start}.editor-panel,.editor-preview{border-radius:var(--radius-card);border:1px solid var(--surface-border);background:var(--surface-card);box-shadow:var(--shadow-soft);padding:1rem}.editor-panel{display:flex;flex-direction:column;gap:.55rem}.editor-panel label{display:flex;flex-direction:column;font-size:.84rem;font-weight:500;color:var(--ink-700);gap:.22rem}.editor-panel input[type=text],.editor-panel input[type=number],.editor-panel textarea,.editor-panel select{padding:.46rem .55rem;border-radius:10px;font-size:.88rem}.editor-panel h3,.editor-preview h3{margin-top:.5rem;margin-bottom:.2rem;font-size:1.05rem}.size-controls{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.65rem}.goal-inputs{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.55rem}.rect-row{display:grid;grid-template-columns:repeat(4,minmax(0,1fr)) auto;gap:.25rem;align-items:center}.rect-row input{width:100%;padding:.35rem .3rem;font-size:.8rem}.hint{font-size:.78rem;color:var(--ink-500);margin:0}.editor-actions{display:flex;gap:.5rem;margin-top:.65rem;flex-wrap:wrap}.validation-errors{background:#fef2f2e6;border:1px solid rgba(252,165,165,.86);border-radius:12px;padding:.55rem .75rem}.validation-errors p{margin:.24rem 0;font-size:.84rem;color:#b91c1c}.status-msg{font-size:.84rem;color:#0f766e}.status-msg.error{color:#b91c1c}.save-success{background:#ecfdf5e6;border:1px solid rgba(110,231,183,.78);border-radius:12px;padding:.68rem .75rem;margin-top:.24rem}.save-success p{margin:0 0 .5rem;font-size:.84rem;color:#065f46}.save-success-actions{display:flex;gap:.4rem;flex-wrap:wrap}.editor-preview{display:flex;flex-direction:column;align-items:center;gap:.85rem}.editor-preview .controls{width:min(640px,100%);display:flex;flex-direction:column;align-items:center;gap:.72rem}.editor-preview .control-buttons{display:flex;gap:.5rem;flex-wrap:wrap;justify-content:center}.edit-tools{display:flex;align-items:center;gap:.45rem;flex-wrap:wrap;justify-content:center}.edit-tools span{font-size:.84rem;color:var(--ink-500)}@media(max-width:920px){.editor-layout{grid-template-columns:1fr}}:root{--ink-900: #10263f;--ink-700: #304a66;--ink-500: #506887;--accent-cyan: #0f7f9a;--accent-cyan-strong: #0d6d85;--accent-ember: #d96e35;--surface-card: rgba(255, 255, 255, .78);--surface-card-strong: rgba(255, 255, 255, .9);--surface-border: rgba(255, 255, 255, .62);--border-soft: rgba(22, 58, 89, .16);--shadow-soft: 0 12px 28px rgba(13, 39, 64, .16);--shadow-strong: 0 20px 42px rgba(12, 36, 60, .2);--radius-card: 20px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-family:Space Grotesk,Avenir Next,Trebuchet MS,sans-serif;line-height:1.45;color:var(--ink-900);background:linear-gradient(160deg,#eef8ff,#f7fcff 48%,#fff8ef)}body{min-height:100vh;color:var(--ink-900)}#root{min-height:100vh}h1,h2,h3{font-family:Fraunces,Georgia,serif;letter-spacing:-.02em;line-height:1.1;color:var(--ink-900)}p{color:var(--ink-700)}a{color:var(--accent-cyan);text-decoration-color:#0f7f9a59;text-underline-offset:2px;transition:color .18s ease,text-decoration-color .18s ease}a:hover{color:var(--accent-cyan-strong);text-decoration-color:#0d6d858c}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.35rem;padding:.5rem .95rem;border:1px solid var(--border-soft);border-radius:999px;background:linear-gradient(155deg,#ffffffeb,#f7fcffd6 50%,#fff6ebe0);box-shadow:0 8px 16px #0c243c14;font-size:.9rem;font-weight:600;letter-spacing:.01em;cursor:pointer;text-decoration:none;color:var(--ink-900);transition:transform .18s ease,box-shadow .18s ease,background .18s ease,border-color .18s ease}.btn:hover{transform:translateY(-1px);box-shadow:0 12px 24px #0c253e24;border-color:#11537552}.btn:active{transform:translateY(0)}.btn:disabled{opacity:.55;cursor:not-allowed;transform:none;box-shadow:none}.btn-primary{background:linear-gradient(140deg,#138ea8,#107b95 45%,#d87135);color:#f8fcff;border-color:#0c607ad9;text-shadow:0 1px 1px rgba(0,0,0,.14);box-shadow:0 10px 24px #0d6c8657,inset 0 1px #ffffff57}.btn-primary:hover{border-color:#0b5b73f2;box-shadow:0 14px 28px #0c5e7761,inset 0 1px #ffffff61}.btn-sm{padding:.34rem .72rem;font-size:.78rem}input[type=text],input[type=number],textarea,select{font:inherit;color:var(--ink-900);border:1px solid rgba(16,66,97,.22);border-radius:12px;background:#ffffffd1;box-shadow:inset 0 1px 2px #0a28400d;outline:none;transition:border-color .15s ease,box-shadow .15s ease,background .15s ease}input:focus,textarea:focus,select:focus{border-color:#0f7f9a9e;box-shadow:0 0 0 3px #189db62e,inset 0 1px 2px #0a284014;background:#ffffffeb}input[type=range]{accent-color:#1288a1}.error{color:#b42318}@keyframes page-rise{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media(max-width:640px){.btn{width:100%}.btn-sm{width:auto}}
