*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{height:100%}body{min-height:100%;background:var(--bg);color:var(--ink);font-family:var(--font-ui);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}body:before{content:"";position:fixed;inset:0;background-image:linear-gradient(rgba(66,190,101,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(66,190,101,.04) 1px,transparent 1px);background-size:32px 32px;pointer-events:none;z-index:0}.page{position:relative;z-index:1;min-height:100vh;display:flex;flex-direction:column;align-items:center;padding:1.75rem 1.25rem 4rem}.header{width:100%;max-width:520px;margin-bottom:2.75rem;display:flex;align-items:center;justify-content:space-between}.logo{text-decoration:none;display:inline-flex;align-items:center;gap:.5rem}.logo__text{font-family:var(--font-display);font-size:22px;font-weight:400;color:var(--ink);letter-spacing:-.02em}.logo__dot{color:var(--cobalt)}.logo:hover .logo__text{opacity:.8}.badge-ondevice{border:1px solid var(--cobalt-border);color:var(--cobalt);font-family:var(--font-ui);font-size:8px;letter-spacing:.15em;text-transform:uppercase;padding:3px 8px}.main{width:100%;max-width:520px;display:flex;flex-direction:column;gap:1rem}.intro{margin-bottom:.25rem}.intro__title{font-family:var(--font-display);font-size:clamp(2rem,7vw,3rem);font-weight:400;letter-spacing:-.01em;line-height:1.05;margin-bottom:.5rem}.intro__sub{font-family:var(--font-display);font-style:italic;font-size:1.125rem;color:var(--ink-mid)}.intro__label{color:#42be65}.drop-zone{position:relative;min-height:140px;display:flex;align-items:center;justify-content:center;border:1.5px dashed rgba(66,190,101,.3);background:#42be6508;overflow:hidden;cursor:pointer;transition:border-color .15s ease,background .15s ease;outline:none}.drop-zone:after{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at center,rgba(66,190,101,.06) 0%,transparent 70%);pointer-events:none}.drop-zone:focus-visible{box-shadow:0 0 0 3px #42be6566}.drop-zone:hover:not(.drop-zone--busy),.drop-zone--drag-over{border-color:#42be65;background:#42be650f}.drop-zone--busy{cursor:default;border-style:solid;border-color:var(--surface-3)}.drop-zone__input{position:absolute;width:1px;height:1px;opacity:0;pointer-events:none}.dz-panel:not([hidden]){display:flex;flex-direction:column;align-items:center;gap:.6rem;padding:1.75rem 1.5rem;text-align:center;pointer-events:none;-webkit-user-select:none;user-select:none;position:relative;z-index:1}.dz-icon{color:var(--ink-dim)}.dz-icon--green{color:#42be65}.dz-primary{font-family:var(--font-ui);font-size:.875rem;font-weight:700;letter-spacing:.04em;color:var(--ink)}.dz-secondary{font-size:11px;color:var(--ink-dim);letter-spacing:.03em}@keyframes layer-pulse{0%,to{opacity:.15}50%{opacity:1}}.fwip-loader .layer-1{animation:layer-pulse 1.2s ease-in-out infinite 0s}.fwip-loader .layer-2{animation:layer-pulse 1.2s ease-in-out infinite .2s}.fwip-loader .layer-3{animation:layer-pulse 1.2s ease-in-out infinite .4s}.fwip-loader .layer-4{animation:layer-pulse 1.2s ease-in-out infinite .6s}.fwip-loader .layer-5{animation:layer-pulse 1.2s ease-in-out infinite .8s}.count-row{display:flex;align-items:center;gap:.75rem}.count-label{font-family:var(--font-ui);font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-dim)}.count-chips{display:flex;gap:.375rem}.count-chip{background:none;border:1px solid rgba(66,190,101,.3);color:var(--ink-mid);font-family:var(--font-ui);font-size:10px;font-weight:700;letter-spacing:.06em;padding:.3rem .625rem;cursor:pointer;transition:border-color .12s,background .12s,color .12s;line-height:1}.count-chip:hover:not(.count-chip--active){border-color:#42be65;color:#42be65}.count-chip--active{background:#42be65;border-color:#42be65;color:var(--bg)}.palette-layout{display:grid;grid-template-columns:2fr 3fr;gap:1rem;align-items:start}.palette-preview{overflow:hidden;border:1px solid var(--surface-3)}.palette-preview img{display:block;width:100%;height:auto}.palette-swatches{display:grid;grid-template-columns:repeat(auto-fill,minmax(70px,1fr));gap:6px}.swatch-card{display:flex;flex-direction:column;border:1px solid var(--surface-3);background:var(--surface);cursor:pointer;transition:border-color .12s,transform .1s;padding:0}.swatch-card:hover{border-color:#42be65;transform:scale(1.04)}.swatch-fill{width:100%;aspect-ratio:1}.swatch-hex{display:block;padding:.35rem .25rem;font-family:var(--font-ui);font-size:9px;font-weight:700;letter-spacing:.04em;color:var(--ink);text-align:center;white-space:nowrap}.palette-strip{display:flex;height:32px;overflow:hidden}.strip-segment{flex:1}.palette-actions{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap;margin-top:10px}.btn-copy-all,.btn-download-palette{background:#42be65;color:var(--bg);border:none;font-family:var(--font-ui);font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:.5rem 1rem;cursor:pointer;transition:opacity .12s ease}.btn-copy-all:hover,.btn-download-palette:hover{opacity:.85}.btn-download-palette{background:none;border:1px solid rgba(66,190,101,.3);color:#42be65}.btn-download-palette:hover{border-color:#42be65;background:#42be6508}.btn-reset{background:none;border:none;font-family:var(--font-ui);font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:#42be65;cursor:pointer;transition:opacity .12s ease;margin-left:auto}.btn-reset:hover{opacity:.75}@keyframes toast-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}.toast{position:fixed;bottom:2rem;left:50%;transform:translate(-50%);background:#42be65;color:var(--bg);font-family:var(--font-ui);font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:.5rem 1.25rem;z-index:100;animation:toast-in .15s ease both}@keyframes fade-up{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}.error-msg{padding:.875rem 1.125rem;background:#ff50500f;border:1px solid rgba(255,80,80,.2);font-size:12px;color:#ff7070;letter-spacing:.02em;animation:fade-up .18s ease both}.trust-row{display:flex;justify-content:space-between;align-items:center;padding-top:.5rem}.trust-item{display:flex;align-items:center;gap:.4rem;font-size:11px;color:var(--ink-dim);letter-spacing:.03em}.trust-dot{width:4px;height:4px;background:var(--green);border-radius:50%;flex-shrink:0}@media(max-width:480px){.page{padding:1.25rem 1rem 3rem}.header{margin-bottom:2rem}.trust-row{flex-direction:column;gap:.5rem;align-items:flex-start}.palette-layout{grid-template-columns:1fr}.palette-actions{flex-direction:column;align-items:flex-start}.btn-reset{margin-left:0}}
