*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{font-family:var(--font-body,system-ui,sans-serif);font-size:16px;color:var(--ink,#0a0a0a);min-height:100vh;overflow-x:hidden;-webkit-font-smoothing:antialiased;line-height:1.45}body:before{content:"";position:fixed;inset:0;pointer-events:none;z-index:0;opacity:.5;mix-blend-mode:multiply;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='1.05' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix values='0 0 0 0 0.4 0 0 0 0 0.4 0 0 0 0 0.5 0 0 0 0.04 0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}body[data-skin].no-grain:before{display:none}a{text-decoration:none}a,button{color:inherit}button{font:inherit;cursor:pointer}img{max-width:100%;display:block}.wrap{position:relative;z-index:1;max-width:1200px;margin:0 auto;padding:18px 22px}body[data-skin=friend] .wrap{padding-left:64px}@media (max-width:600px){body[data-skin=friend] .wrap{padding-left:52px}}.nav{display:flex;justify-content:space-between;padding:4px 0 32px}.brand-link,.nav{align-items:center}.brand-link{display:inline-flex}body[data-skin=friend] .brand-link{transform:rotate(-2deg)}.nav-right{gap:10px}.nav-pill,.nav-right{display:inline-flex;align-items:center}.nav-pill{background:var(--ink);color:var(--paper);padding:8px 14px;border-radius:999px;font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;gap:6px}.nav-pill:before{content:"●";color:var(--accent-1);animation:pulse 1.6s ease-in-out infinite}body[data-skin=editorial] .nav-pill{text-transform:uppercase;font-family:var(--font-mono);font-size:10px;letter-spacing:.14em;background:transparent;color:var(--ink-soft);padding:0;border-radius:0}@media (max-width:600px){.nav-right .nav-pill{display:none}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.3}}.vibe-chip{display:inline-flex;align-items:center;gap:8px;background:var(--paper);color:var(--ink);border:var(--border-w) solid var(--ink);padding:7px 14px;border-radius:999px;font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;transition:all .2s;font-family:var(--font-body);box-shadow:0 0 0 0 var(--accent-1);animation:chipPulse 2.4s ease-out 1.5s 2}.vibe-chip-icon{font-size:13px;opacity:.6}.vibe-chip:hover{background:var(--ink);color:var(--paper)}.vibe-chip-swatch{width:14px;height:14px;border-radius:50%;border:1.5px solid var(--ink);flex-shrink:0}.vibe-chip:hover .vibe-chip-swatch{border-color:var(--paper)}body[data-skin=editorial] .vibe-chip{text-transform:none;letter-spacing:0;font-style:italic;font-family:var(--font-serif);font-weight:400;font-size:14px}body[data-skin=friend] .vibe-chip{font-family:Bagel Fat One,system-ui,sans-serif;font-weight:400;text-transform:lowercase;letter-spacing:0;font-size:14px;background:var(--accent-2);color:var(--ink);transform:rotate(1deg)}@keyframes chipPulse{0%{box-shadow:0 0 0 0 rgba(255,122,174,.7)}60%{box-shadow:0 0 0 14px rgba(255,122,174,0)}to{box-shadow:0 0 0 0 rgba(255,122,174,0)}}.vibe-modal{position:fixed;inset:0;z-index:100;background:rgba(26,15,46,.6);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;padding:20px;animation:rise .3s ease}.vibe-modal-card{background:var(--paper);border:var(--border-w) solid var(--ink);border-radius:var(--radius);padding:28px;max-width:520px;width:100%;box-shadow:6px 6px 0 var(--ink)}.vibe-modal-h{font-family:var(--font-display);font-weight:800;font-size:32px;letter-spacing:-.025em;line-height:1.1;margin-bottom:6px}body[data-skin=editorial] .vibe-modal-h{font-weight:350}body[data-skin=friend] .vibe-modal-h{font-family:Bagel Fat One,system-ui,sans-serif;font-weight:400;text-transform:lowercase}.vibe-modal-sub{font-size:14px;color:var(--ink-soft);margin-bottom:22px}.vibe-grid{display:grid;grid-template-columns:1fr;grid-gap:10px;gap:10px}.vibe-tile{display:flex;align-items:center;gap:14px;padding:14px 16px;background:var(--paper);border:var(--border-w) solid var(--ink);border-radius:var(--radius-sm);text-align:left;font-family:var(--font-body);transition:all .2s}.vibe-tile:hover{transform:translate(-2px,-2px);box-shadow:4px 4px 0 var(--accent-1)}.vibe-tile.is-active{background:var(--ink);color:var(--paper)}.vibe-tile-swatch{width:42px;height:42px;border-radius:50%;flex-shrink:0;border:2px solid var(--ink)}.vibe-tile.is-active .vibe-tile-swatch{border-color:var(--paper)}.vibe-tile-meta{display:flex;flex-direction:column;gap:2px;min-width:0}.vibe-tile-name{font-family:var(--font-display);font-weight:700;font-size:17px;letter-spacing:-.015em}body[data-skin=editorial] .vibe-tile-name{font-weight:400;font-style:italic}body[data-skin=friend] .vibe-tile-name{font-family:Bagel Fat One,system-ui,sans-serif;font-weight:400;text-transform:lowercase}.vibe-tile-desc{font-size:12px;color:var(--ink-soft);font-weight:500}.vibe-tile.is-active .vibe-tile-desc{color:hsla(0,0%,100%,.8)}.vibe-modal-close{margin-top:18px;font-size:12px;color:var(--ink-faded);background:none;border:0;text-decoration:underline;text-underline-offset:4px;font-family:var(--font-body)}.sparkle{position:fixed;pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none;z-index:1;animation:float 4s ease-in-out infinite,sparkleSpin 8s linear infinite}.sparkle.s1{top:8%;left:6%;font-size:26px}.sparkle.s2{top:18%;right:12%;font-size:18px;animation-delay:.6s}.sparkle.s3{top:52%;left:4%;font-size:32px;animation-delay:1.2s}.sparkle.s4{top:38%;right:8%;font-size:22px;animation-delay:1.8s}.sparkle.s5{top:70%;right:4%;font-size:16px;animation-delay:2.4s}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-12px)}}@keyframes sparkleSpin{to{transform:rotate(1turn)}}@media (max-width:600px){.sparkle.s2,.sparkle.s4,.sparkle.s5{display:none}}.btn-primary{border:0;background:var(--ink);color:var(--paper);font:700 15px/1 var(--font-body);letter-spacing:.02em;padding:18px 24px;border-radius:999px;white-space:nowrap;display:inline-flex;align-items:center;gap:10px;transition:all .2s;position:relative;overflow:hidden}.btn-primary:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,var(--accent-1),var(--accent-2));opacity:0;transition:opacity .2s}.btn-primary>*{position:relative;z-index:1}.btn-primary:hover:before{opacity:1}body[data-skin=editorial] .btn-primary{border-radius:22px;font-weight:500;letter-spacing:0;font-size:14px;background:var(--accent-1);color:var(--paper)}body[data-skin=editorial] .btn-primary:before{display:none}body[data-skin=editorial] .btn-primary:hover{background:var(--ink)}body[data-skin=friend] .btn-primary{background:var(--accent-1);color:var(--paper);border:3px solid var(--ink);font-family:Bagel Fat One,system-ui,sans-serif;font-weight:400;text-transform:lowercase;font-size:18px;border-radius:999px;padding:16px 26px;box-shadow:5px 5px 0 var(--ink);transform:rotate(-1deg)}body[data-skin=friend] .btn-primary:before{display:none}body[data-skin=friend] .btn-primary:hover{transform:rotate(-1deg) translate(-2px,-2px);box-shadow:7px 7px 0 var(--ink);background:var(--ink);color:var(--accent-2)}.btn-ghost{border:var(--border-w) solid var(--ink);background:transparent;color:var(--ink);font:600 14px/1 var(--font-body);letter-spacing:.02em;padding:16px 22px;border-radius:999px;transition:all .2s}.btn-ghost:hover{background:var(--ink);color:var(--paper)}body[data-skin=friend] .btn-ghost{background:var(--paper);border:3px solid var(--ink);font-family:Caveat,cursive;font-weight:700;font-size:19px;text-transform:lowercase;border-radius:999px;padding:14px 22px;box-shadow:4px 4px 0 var(--accent-1);transform:rotate(.5deg);-webkit-text-stroke:.5px currentColor}.eyebrow{display:inline-flex;align-items:center;gap:8px;background:var(--paper);border:var(--border-w) solid var(--ink);padding:6px 14px 6px 10px;border-radius:999px;font-size:12px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;margin-bottom:24px;align-self:flex-start;box-shadow:4px 4px 0 var(--ink);font-family:var(--font-body)}.eyebrow .dot{color:var(--accent-1)}body[data-skin=editorial] .eyebrow{box-shadow:none;text-transform:none;font-family:var(--font-mono);font-size:11px;letter-spacing:.16em}body[data-skin=friend] .eyebrow{font-family:Caveat,cursive;font-weight:700;font-size:18px;letter-spacing:0;text-transform:lowercase;background:var(--accent-2);border-color:var(--ink);border-radius:4px 16px 4px 16px;transform:rotate(-1.5deg);box-shadow:4px 4px 0 var(--ink);padding:8px 16px;-webkit-text-stroke:.5px currentColor}.h1{font-family:var(--font-display);font-weight:800;font-size:clamp(54px,11vw,132px);line-height:.9;letter-spacing:-.045em;margin-bottom:24px;color:var(--ink)}body[data-skin=editorial] .h1{font-weight:350;font-size:clamp(48px,9vw,116px);line-height:.96;letter-spacing:-.03em}body[data-skin=friend] .h1{font-family:Bagel Fat One,system-ui,sans-serif;font-size:clamp(46px,8.5vw,104px);line-height:.98;text-transform:lowercase}.h1 em,body[data-skin=friend] .h1{font-weight:400;letter-spacing:-.02em}.h1 em{font-family:var(--font-serif);font-style:var(--font-serif-style);background:linear-gradient(120deg,var(--accent-1),var(--accent-2),var(--accent-3));-webkit-background-clip:text;background-clip:text;color:transparent}body[data-skin=editorial] .h1 em{font-weight:400}body[data-skin=editorial] .h1 em,body[data-skin=friend] .h1 em{background:none;-webkit-background-clip:initial;background-clip:initial;color:var(--accent-1)}body[data-skin=friend] .h1 em{font-family:Caveat,cursive;font-weight:700;font-size:1.2em;display:inline-block;transform:rotate(-3deg) translateY(8px);letter-spacing:0;line-height:.85;position:relative;padding:0 .05em;-webkit-text-stroke:.5px currentColor}body[data-skin=friend] .h1 em:after{content:"";position:absolute;left:0;right:0;bottom:12%;height:14px;background:var(--accent-2);z-index:-1;transform:rotate(-1deg);border-radius:50%}.sub{font-size:18px;line-height:1.5;color:var(--ink-soft);max-width:560px;margin-bottom:32px;font-weight:500}body[data-skin=editorial] .sub{font-weight:400}@media (min-width:700px){.sub{font-size:20px}}.scan-form{background:var(--paper);border:var(--border-w) solid var(--ink);border-radius:var(--radius);padding:8px;display:flex;gap:8px;max-width:720px;align-items:stretch;box-shadow:var(--shadow-offset) var(--shadow-offset) 0 var(--ink);transition:transform .2s,box-shadow .2s}body[data-skin=editorial] .scan-form{box-shadow:0 24px 48px -28px hsla(0,0%,4%,.18)}.scan-form:focus-within{transform:translate(-2px,-2px);box-shadow:calc(var(--shadow-offset) + 2px) calc(var(--shadow-offset) + 2px) 0 var(--accent-1)}.scan-form input{flex:1 1;border:0;background:transparent;padding:18px;font:500 16px/1.4 var(--font-body);color:var(--ink);outline:none;min-width:0}.scan-form input::placeholder{color:var(--ink-faded)}.scan-btn{border:0;background:var(--ink);color:var(--paper);font:700 14px/1 var(--font-body);padding:0 22px;border-radius:var(--radius-sm);white-space:nowrap;display:inline-flex;align-items:center;gap:8px;transition:background .2s}.scan-btn:hover{background:var(--accent-2)}@media (max-width:600px){.scan-form{flex-direction:column;padding:6px}.scan-btn,.scan-form input{padding:14px}.scan-btn{width:100%;justify-content:center}}body[data-skin=friend] .scan-form{border:3px solid var(--ink);box-shadow:5px 5px 0 var(--ink);transform:rotate(-.5deg)}body[data-skin=friend] .scan-btn{background:var(--accent-1);font-family:Bagel Fat One,system-ui,sans-serif;text-transform:lowercase}@keyframes rise{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.r{opacity:0;transform:translateY(14px);animation:rIn .8s cubic-bezier(.2,.8,.2,1) forwards}.r-1{animation-delay:.05s}.r-2{animation-delay:.18s}.r-3{animation-delay:.32s}.r-4{animation-delay:.46s}.r-5{animation-delay:.6s}@keyframes rIn{to{opacity:1;transform:translateY(0)}}