@font-face{font-family:Essentielle;src:url(/assets/fonts/Essentielle-Black_DesktopPC.ttf) format("truetype");font-display:block}:root{--gold: #d5a74d;--gold-light: #fff06f;--black: #000000;--white: #ffffff;--stage-width: min(100vw, 56.25dvh )}*{box-sizing:border-box}html,body,#root{width:100%;height:100%;margin:0;overflow:hidden;background:var(--black);color:var(--white);font-family:Essentielle,Arial,sans-serif;letter-spacing:0;touch-action:manipulation}button,a{font:inherit;letter-spacing:0}.app{position:relative;width:100vw;height:100dvh;display:grid;place-items:center;background:var(--black);overflow:hidden}.stage{position:relative;grid-area:1 / 1;z-index:1;width:var(--stage-width);height:100dvh;max-height:calc(100vw * 1920 / 1080);aspect-ratio:1080 / 1920;overflow:hidden;background:var(--black)}.page-wipe{position:absolute;top:0;bottom:0;left:50%;z-index:40;width:max(54vw,42dvh);pointer-events:none}.page-wipe-core{width:100%;height:100%;transform:skew(-10deg);background:linear-gradient(90deg,transparent 0%,rgba(0,0,0,.94) 14%,rgba(213,167,77,.96) 48%,rgba(255,240,111,.98) 52%,rgba(0,0,0,.94) 86%,transparent 100%);box-shadow:0 0 42px #fff06f85,0 0 110px #d5a74d3d}.screen-bg{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:fill;-webkit-user-select:none;user-select:none;pointer-events:none}.full-hit{position:absolute;top:0;right:0;bottom:0;left:0;border:0;background:transparent;cursor:pointer}.icon-button{position:absolute;z-index:8;width:clamp(58px,7dvh,92px);height:clamp(58px,7dvh,92px);display:grid;place-items:center;border:3px solid var(--gold);border-radius:50%;background:#0000007a;color:var(--white);line-height:1;cursor:pointer}.icon-button svg{width:56%;height:56%}.icon-button:disabled{opacity:.35;pointer-events:none}.back-button{top:6.4%;left:7%}.recapture-button{top:6.4%;right:7%}.template-hotspots{position:absolute;top:0;right:0;bottom:0;left:0}.template-button{position:absolute;border:2px solid transparent;background:#ffffff03;cursor:pointer}.template-button:focus-visible,.template-button:active{outline:0;border-color:var(--gold-light);box-shadow:0 0 0 8px #fff06f47}.camera-ui,.processing-ui,.result-ui,.public-result-ui{position:absolute;top:7.8%;right:7%;bottom:8.4%;left:7%;display:flex;flex-direction:column;align-items:center;text-align:center}.camera-ui{cursor:pointer}.camera-ui h1,.processing-ui h1,.public-result-ui h1{margin:15% 0 6%;font-size:clamp(2rem,5.4dvh,5.5rem);line-height:1.06;font-weight:900}.camera-frame{position:relative;width:78%;aspect-ratio:3 / 4;border:4px solid var(--gold);overflow:hidden;background:#111;box-shadow:0 0 #fff06f00}.screen-capture-flash{position:absolute;top:0;right:0;bottom:0;left:0;z-index:20;background:radial-gradient(circle at center,#fff,#fffffff5 40%,#fff06fb3 72%,#fff0);pointer-events:none}.camera-frame video,.captured-preview{width:100%;height:100%;object-fit:cover}.camera-frame video{transform:scaleX(-1)}.camera-frame video.is-hidden{display:none}.captured-preview,.capture-flash{position:absolute;top:0;right:0;bottom:0;left:0}.capture-flash{z-index:4;background:#fff;pointer-events:none}.countdown{position:absolute;top:0;right:0;bottom:0;left:0;z-index:5;display:grid;place-items:center;background:#00000061;font-size:clamp(6rem,20dvh,15rem);line-height:1;color:var(--white)}.gold-button,.outline-button{min-height:86px;padding:0 28px;border-radius:0;color:var(--white);font-size:clamp(1.25rem,3.4dvh,3rem);line-height:1;text-decoration:none;cursor:pointer}.gold-button{border:3px solid var(--gold-light);background:linear-gradient(90deg,#ba8642,var(--gold-light));color:var(--black)}.outline-button{border:3px solid var(--gold);background:transparent}.camera-hint{width:78%;min-height:1.2em;margin:6% 0 0;font-size:clamp(1.35rem,3.2dvh,2.8rem);line-height:1}.status-message{min-height:2.4em;max-width:78%;margin:5% 0 0;color:#ffdfdf;font-size:clamp(1rem,2.3dvh,1.9rem);line-height:1.25}.processing-ui{justify-content:center;padding-bottom:23%}.processing-ui h1{margin:0 0 8%}.hair-loader{position:relative;width:72%;display:grid;justify-items:center;gap:clamp(18px,2.6dvh,34px)}.hair-loader-swatches{width:100%;display:grid;grid-template-columns:repeat(8,1fr);gap:clamp(8px,1.1dvh,14px);align-items:end}.hair-loader-swatches span{display:block;aspect-ratio:1;border:2px solid rgba(255,255,255,.18);box-shadow:0 0 24px #fff06f24}.hair-progress-track{position:relative;width:100%;height:clamp(24px,3.2dvh,42px);overflow:hidden;border:3px solid var(--gold);background:#ffffff14;box-shadow:inset 0 0 18px #000c,0 0 34px #d5a74d3d}.hair-progress-fill{position:absolute;inset:0 auto 0 0;min-width:8%;overflow:hidden;background:linear-gradient(90deg,#6f4a2d,#111,#efe1bf,#a95a3d,#2b2e31,#b77a3b,#c8b8a2 84%,#bd512f);box-shadow:0 0 28px #fff06f57}.hair-progress-shine{position:absolute;top:0;bottom:0;width:38%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.72),transparent);transform:skew(-18deg)}.hair-progress-glow{width:82%;height:4px;background:linear-gradient(90deg,transparent,rgba(255,240,111,.86),transparent);filter:blur(6px)}.result-ui{justify-content:center;padding-bottom:14%;pointer-events:none}.qr-card{width:48%;aspect-ratio:1;display:grid;place-items:center;background:var(--white);margin-top:10%}.qr-card img{width:94%;height:94%;object-fit:contain}.result-status{width:72%;min-height:4.2em;margin:6% 0 4%;font-size:clamp(1.2rem,3dvh,2.7rem);line-height:1.2}.public-result-ui{justify-content:center;padding-bottom:18%}.public-result-ui h1{margin-top:0}.public-result-ui p{width:78%;min-height:3em;font-size:clamp(1.2rem,3dvh,2.5rem);line-height:1.25}.public-result-ui video,.public-result-ui img{width:78%;max-height:48%;object-fit:contain;border:3px solid var(--gold);background:#111}.link-button{display:inline-grid;place-items:center;min-width:38%;margin-top:5%}@media(orientation:landscape){.camera-ui h1,.processing-ui h1,.public-result-ui h1{font-size:clamp(1.8rem,5dvh,4.8rem)}}
