@font-face{font-family:Bricolage Grotesque;font-style:normal;font-weight:400;font-stretch:100%;font-display:swap;src:url(/_next/static/media/93a6e477e1480c92-s.woff2) format("woff2");unicode-range:u+0102-0103,u+0110-0111,u+0128-0129,u+0168-0169,u+01a0-01a1,u+01af-01b0,u+0300-0301,u+0303-0304,u+0308-0309,u+0323,u+0329,u+1ea0-1ef9,u+20ab}@font-face{font-family:Bricolage Grotesque;font-style:normal;font-weight:400;font-stretch:100%;font-display:swap;src:url(/_next/static/media/c7e0cf6c760983e7-s.woff2) format("woff2");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:Bricolage Grotesque;font-style:normal;font-weight:400;font-stretch:100%;font-display:swap;src:url(/_next/static/media/9d5a263311222317-s.p.woff2) format("woff2");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:Bricolage Grotesque;font-style:normal;font-weight:600;font-stretch:100%;font-display:swap;src:url(/_next/static/media/93a6e477e1480c92-s.woff2) format("woff2");unicode-range:u+0102-0103,u+0110-0111,u+0128-0129,u+0168-0169,u+01a0-01a1,u+01af-01b0,u+0300-0301,u+0303-0304,u+0308-0309,u+0323,u+0329,u+1ea0-1ef9,u+20ab}@font-face{font-family:Bricolage Grotesque;font-style:normal;font-weight:600;font-stretch:100%;font-display:swap;src:url(/_next/static/media/c7e0cf6c760983e7-s.woff2) format("woff2");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:Bricolage Grotesque;font-style:normal;font-weight:600;font-stretch:100%;font-display:swap;src:url(/_next/static/media/9d5a263311222317-s.p.woff2) format("woff2");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:Bricolage Grotesque;font-style:normal;font-weight:800;font-stretch:100%;font-display:swap;src:url(/_next/static/media/93a6e477e1480c92-s.woff2) format("woff2");unicode-range:u+0102-0103,u+0110-0111,u+0128-0129,u+0168-0169,u+01a0-01a1,u+01af-01b0,u+0300-0301,u+0303-0304,u+0308-0309,u+0323,u+0329,u+1ea0-1ef9,u+20ab}@font-face{font-family:Bricolage Grotesque;font-style:normal;font-weight:800;font-stretch:100%;font-display:swap;src:url(/_next/static/media/c7e0cf6c760983e7-s.woff2) format("woff2");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:Bricolage Grotesque;font-style:normal;font-weight:800;font-stretch:100%;font-display:swap;src:url(/_next/static/media/9d5a263311222317-s.p.woff2) format("woff2");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:Bricolage Grotesque Fallback;src:local("Arial");ascent-override:88.21%;descent-override:25.61%;line-gap-override:0.00%;size-adjust:105.43%}.__className_4ed91e{font-family:Bricolage Grotesque,Bricolage Grotesque Fallback;font-style:normal}.__variable_4ed91e{--font-bricolage:"Bricolage Grotesque","Bricolage Grotesque Fallback"}@font-face{font-family:DM Mono;font-style:normal;font-weight:400;font-display:swap;src:url(/_next/static/media/64418ffc17e50301-s.woff2) format("woff2");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:DM Mono;font-style:normal;font-weight:400;font-display:swap;src:url(/_next/static/media/0e96d314a90a6138-s.p.woff2) format("woff2");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:DM Mono;font-style:normal;font-weight:500;font-display:swap;src:url(/_next/static/media/ba43ea3467e29870-s.woff2) format("woff2");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:DM Mono;font-style:normal;font-weight:500;font-display:swap;src:url(/_next/static/media/b7ea2ab4a8ad1f81-s.p.woff2) format("woff2");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:DM Mono Fallback;src:local("Arial");ascent-override:73.71%;descent-override:23.03%;line-gap-override:0.00%;size-adjust:134.59%}.__className_9ef920{font-family:DM Mono,DM Mono Fallback;font-style:normal}.__variable_9ef920{--font-dm-mono:"DM Mono","DM Mono Fallback"}

/*! tailwindcss v4.2.1 | MIT License | https://tailwindcss.com */@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,::backdrop,:after,:before{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-outline-style:solid;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial;--tw-backdrop-blur:initial;--tw-backdrop-brightness:initial;--tw-backdrop-contrast:initial;--tw-backdrop-grayscale:initial;--tw-backdrop-hue-rotate:initial;--tw-backdrop-invert:initial;--tw-backdrop-opacity:initial;--tw-backdrop-saturate:initial;--tw-backdrop-sepia:initial;--tw-ease:initial}}}@layer theme{:host,:root{--spacing:.25rem;--radius-md:.375rem;--radius-lg:.5rem;--ease-out:cubic-bezier(0,0,.2,1);--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4,0,.2,1);--default-font-family:var(--font-bricolage);--default-mono-font-family:var(--font-dm-mono)}}@layer base{*,::backdrop,:after,:before{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}:host,html{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{font-family:var(--default-mono-font-family,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}menu,ol,ul{list-style:none}audio,canvas,embed,iframe,img,object,svg,video{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,optgroup,select,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit,::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-day-field,::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-hour-field,::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-millisecond-field,::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.fixed{position:fixed}.static{position:static}.start{inset-inline-start:var(--spacing)}.container{width:100%}@media (min-width:40rem){.container{max-width:40rem}}@media (min-width:48rem){.container{max-width:48rem}}@media (min-width:64rem){.container{max-width:64rem}}@media (min-width:80rem){.container{max-width:80rem}}@media (min-width:96rem){.container{max-width:96rem}}.flex{display:flex}.grid{display:grid}.hidden{display:none}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.rounded{border-radius:.25rem}.border{border-style:var(--tw-border-style);border-width:1px}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.filter{filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}.backdrop-filter{-webkit-backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,);backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.ease-out{--tw-ease:var(--ease-out);transition-timing-function:var(--ease-out)}}:root{--bg-base:#050505;--bg-elevated:#0a0a0c;--text-main:#f4f4f5;--text-muted:#a1a1aa;--surface:#18181b;--surface-hover:#27272a;--accent:#e4e4e7;--line:#ffffff14;--radius-lg:24px;--radius-md:16px;--radius-sm:12px;--shadow-soft:0 10px 30px #00000059;--shadow-card:0 16px 28px #00000047;--easing-spring:cubic-bezier(.175,.885,.32,1.15);--easing-fast:cubic-bezier(.1,1,.2,1);color-scheme:dark}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent;margin:0;padding:0}body,html{background-color:var(--bg-base);overflow-x:hidden}body{min-height:100dvh;color:var(--text-main);font-family:var(--font-bricolage),sans-serif;overscroll-behavior:none;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noiseFilter'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noiseFilter)' opacity='0.08'/%3E%3C/svg%3E");justify-content:center;display:flex}img{max-width:100%;height:auto}button,input,textarea{font:inherit}button{cursor:pointer}a{color:inherit;text-decoration:none}:focus-visible{outline:none;box-shadow:0 0 0 4px #ffffff1f}.kartu-page{justify-content:center;width:100%;display:flex}.app-container{-webkit-backdrop-filter:blur(20px);isolation:isolate;background:linear-gradient(#050505e0,#08080ad1);border-left:1px solid #ffffff0d;border-right:1px solid #ffffff0d;width:100%;max-width:440px;min-height:100dvh;position:relative;overflow:hidden auto;box-shadow:0 0 40px #00000080}.app-container:before{content:"";pointer-events:none;z-index:-1;filter:blur(22px);background:radial-gradient(circle at top,#00d1ff29,#0000 46%),radial-gradient(circle at 70% 20%,#e4e4e714,#0000 42%);height:360px;position:absolute;inset:-20% -10% auto}.app-container::-webkit-scrollbar{display:none}.app-container{-ms-overflow-style:none;scrollbar-width:none}.app-header{z-index:10;-webkit-backdrop-filter:blur(10px);background:linear-gradient(#050505f5,#050505d1 72%,#05050500);justify-content:space-between;padding:32px 24px 20px;position:sticky;top:0}.app-header,.brand-cluster{align-items:flex-end;display:flex}.brand-cluster{gap:14px}.brand-mark{background:#ffffff0a;border-radius:16px;flex-shrink:0;width:44px;height:44px;overflow:hidden;box-shadow:0 8px 18px #0003,inset 0 1px #ffffff0f}.brand-mark img{width:100%;height:100%;display:block}.header-titles h1{letter-spacing:-.05em;font-size:clamp(2.35rem,6vw,2.6rem);font-weight:800;line-height:.95}.header-titles p{font-family:var(--font-dm-mono),monospace;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin-top:8px;font-size:.85rem}.add-btn{background:var(--text-main);color:var(--bg-base);width:48px;height:48px;transition:transform .3s var(--easing-spring),background .2s ease,box-shadow .2s ease;border:none;border-radius:999px;justify-content:center;align-items:center;display:flex;box-shadow:0 4px 14px #ffffff26}.add-btn:hover{background:#fff;transform:scale(.96)rotate(90deg);box-shadow:0 8px 22px #ffffff2e}.add-btn:active{transform:scale(.92)rotate(90deg)}.ui-icon{width:1.45rem;height:1.45rem;display:block}.grid-container{grid-template-columns:repeat(2,minmax(0,1fr));align-content:start;gap:16px;padding:4px 24px 120px;display:grid}.card-wrapper{opacity:0;animation:slideUp .8s var(--easing-spring) forwards;transform:translateY(40px)}@keyframes slideUp{to{opacity:1;transform:translateY(0)}}.card{aspect-ratio:16/9;border-radius:var(--radius-lg);width:100%;box-shadow:var(--shadow-card);text-align:left;border:none;flex-direction:column;justify-content:space-between;padding:18px;transition:transform .2s cubic-bezier(.175,.885,.32,1.5),box-shadow .2s,filter .2s;display:flex;position:relative;overflow:hidden}.card:before{opacity:.7;background:radial-gradient(circle at 100% 0,#ffffff47,#0000 35%)}.card:after,.card:before{content:"";pointer-events:none;position:absolute;inset:0}.card:after{border-radius:inherit;mix-blend-mode:overlay;background:linear-gradient(135deg,#ffffff52,#fff0 38%,#0000001f)}.card:hover{transform:translateY(-2px)scale(1.015);box-shadow:0 20px 34px #00000052}.card:active{transform:scale(.95);box-shadow:0 8px 16px #00000047}.card.pressing{filter:brightness(.74);transition:transform .4s,filter .4s;transform:scale(.92)}.card:focus-visible{box-shadow:0 0 0 4px #fff3,var(--shadow-card)}.card-top{z-index:1;justify-content:space-between;align-items:flex-start;gap:12px;display:flex;position:relative}.card-logo{letter-spacing:-.05em;font-size:2rem;font-weight:800;line-height:1}.card-icon{opacity:.84;flex-shrink:0;width:2rem;height:2rem}.card-icon .ui-icon{width:100%;height:100%}.card-bottom{z-index:1;position:relative}.card-name{letter-spacing:-.02em;margin-bottom:6px;font-size:1.05rem;font-weight:600}.card-meta{font-family:var(--font-dm-mono),monospace;opacity:.75;letter-spacing:.12em;text-transform:uppercase;font-size:.75rem}.empty-state{box-shadow:var(--shadow-soft);text-align:center;background:#ffffff08;border:1px solid #ffffff0f;border-radius:28px;flex-direction:column;grid-column:1/-1;align-items:center;margin-top:24px;padding:28px 24px;display:flex}.empty-icon{border-radius:24px;width:72px;height:72px;margin-bottom:18px;animation:floatUp 3s ease-in-out infinite;overflow:hidden;box-shadow:0 10px 30px #00000059}@keyframes floatUp{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}.empty-state h2{letter-spacing:-.03em;font-size:1.5rem;font-weight:700}.empty-state p{color:var(--text-muted);max-width:28ch;margin-top:10px;line-height:1.6}.empty-btn{width:100%;margin-top:22px}.modal-overlay{-webkit-backdrop-filter:blur(8px);z-index:100;opacity:0;pointer-events:none;background:#000c;transition:opacity .2s;position:absolute;inset:0}.modal-overlay.active{opacity:1;pointer-events:all}.bottom-sheet{background:var(--surface);width:100%;height:85%;transition:transform .25s var(--easing-fast);z-index:101;border-top:1px solid #ffffff1a;border-radius:32px 32px 0 0;flex-direction:column;padding:32px 24px 36px;display:flex;position:absolute;bottom:0;left:0;overflow-y:auto;transform:translateY(100%);box-shadow:0 -20px 60px #00000059}.modal-overlay.active .bottom-sheet{transform:translateY(0)}.sheet-handle{background:#fff3;border-radius:999px;width:40px;height:4px;margin:-16px auto 24px}.sheet-header{justify-content:space-between;align-items:center;gap:12px;margin-bottom:28px;display:flex}.sheet-header h2{letter-spacing:-.02em;font-size:1.5rem;font-weight:600}.close-btn{color:var(--text-main);background:#ffffff0d;border:none;border-radius:999px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;transition:background .2s,transform .2s;display:flex}.close-btn:hover{background:#ffffff1a;transform:scale(.96)}.close-btn:active{transform:scale(.92)}.scanner-container{aspect-ratio:1;border-radius:var(--radius-md);background:#000;width:100%;margin-bottom:18px;position:relative;overflow:hidden;box-shadow:inset 0 0 40px #000c}.scanner-video{object-fit:cover;border-radius:inherit;width:100%;height:100%;position:absolute;inset:0}.scanner-status{-webkit-backdrop-filter:blur(8px);color:var(--text-main);font-size:.85rem;font-family:var(--font-dm-mono),monospace;white-space:nowrap;z-index:5;animation:fadeInUp .3s var(--easing-fast);background:#000000bf;border-radius:999px;align-items:center;gap:8px;padding:10px 18px;display:flex;position:absolute;bottom:20px;left:50%;transform:translate(-50%)}.scanner-status-dot{background:#facc15;border-radius:50%;width:8px;height:8px;animation:pulse 1.2s ease-in-out infinite}.scanner-error{color:#fca5a5}.scanner-success{color:#86efac;background:#000000d9}@keyframes fadeInUp{0%{opacity:0;transform:translate(-50%)translateY(8px)}to{opacity:1;transform:translate(-50%)translateY(0)}}@keyframes pulse{50%{opacity:.5}}.scanner-copy{color:var(--text-muted);margin-bottom:24px;line-height:1.6}.scanner-brackets{border:2px solid #ffffff1a;border-radius:12px;position:absolute;inset:30px}.scanner-brackets-inner:after,.scanner-brackets-inner:before,.scanner-brackets:after,.scanner-brackets:before{content:"";border-color:var(--text-main);border-style:solid;width:30px;height:30px;position:absolute}.scanner-brackets:before{border-width:3px 0 0 3px;border-top-left-radius:12px;top:-2px;left:-2px}.scanner-brackets:after{border-width:0 3px 3px 0;border-bottom-right-radius:12px;bottom:-2px;right:-2px}.scanner-brackets-inner{position:absolute;inset:0}.scanner-brackets-inner:before{border-width:3px 3px 0 0;border-top-right-radius:12px;top:-2px;right:-2px}.scanner-brackets-inner:after{border-width:0 0 3px 3px;border-bottom-left-radius:12px;bottom:-2px;left:-2px}.scan-line{background:#ff2e63;width:100%;height:2px;animation:scan 2.5s linear infinite;position:absolute;top:10%;left:0;box-shadow:0 0 15px #ff2e63,0 0 30px #ff2e63}@keyframes scan{0%{opacity:0;top:10%}10%{opacity:1}90%{opacity:1}to{opacity:0;top:90%}}.divider{text-align:center;color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em;font-size:.8rem;font-family:var(--font-dm-mono),monospace;align-items:center;margin-bottom:24px;display:flex}.divider:after,.divider:before{content:"";border-bottom:1px solid #ffffff0d;flex:1}.divider:not(:empty):before{margin-right:16px}.divider:not(:empty):after{margin-left:16px}.manual-form{flex-direction:column;gap:12px;display:flex}.input-group{gap:12px;display:flex;position:relative}.input-field{color:var(--text-main);font-family:var(--font-dm-mono),monospace;background:#00000080;border:1px solid #ffffff1a;border-radius:12px;outline:none;flex:1;padding:16px 20px;font-size:1rem;transition:border-color .3s,box-shadow .3s,background .3s}.input-field:focus{background:#000000a8;border-color:#ffffff80;box-shadow:0 0 0 4px #ffffff0d}.input-field::placeholder{color:#52525b}.input-field.full-width{width:100%}.submit-btn{background:var(--text-main);color:var(--bg-base);font-family:var(--font-bricolage),sans-serif;border:none;border-radius:12px;justify-content:center;align-items:center;padding:16px 24px;font-size:1rem;font-weight:600;transition:transform .2s,background .2s,opacity .2s;display:flex}.submit-btn:hover{background:#d4d4d8;transform:scale(.98)}.submit-btn:active{transform:scale(.96)}.submit-btn:disabled{opacity:.45;cursor:not-allowed;transform:none}.helper-text{color:var(--text-muted);font-size:.92rem;line-height:1.6}#barcodeModal .bottom-sheet{color:#050505;background:#fff;height:auto;min-height:45%;padding-bottom:48px}#barcodeModal .sheet-header h2{color:#050505}#barcodeModal .close-btn{color:#050505;background:#0000000d}#barcodeModal .close-btn:hover{background:#0000001a}#barcodeModal .sheet-handle{background:#0003}.barcode-container{flex-direction:column;align-items:center;margin-top:-4px;margin-bottom:16px;display:flex}.barcode-card-preview{border-radius:18px;justify-content:space-between;align-items:center;gap:12px;width:100%;max-width:280px;padding:14px 16px;display:flex;box-shadow:0 12px 24px #00000026}.barcode-card-logo{letter-spacing:-.04em;font-size:1.25rem;font-weight:800}.barcode-card-name{font-size:.95rem;font-weight:600}.barcode-render{justify-content:center;align-items:center;width:100%;max-width:300px;margin:18px 0 28px;display:flex}.barcode-canvas{width:100%;height:auto;max-height:110px;image-rendering:pixelated;border-radius:4px;display:block}.barcode-fallback{opacity:.6;justify-content:center;align-items:center;width:100%;height:90px;display:flex}.barcode-number{font-family:var(--font-dm-mono),monospace;letter-spacing:.15em;color:#050505;text-align:center;font-size:1.1rem;font-weight:500}.barcode-caption{color:#52525b;text-align:center;max-width:32ch;margin-top:18px;line-height:1.6}.input-label{color:var(--text-muted);font-size:.85rem;font-family:var(--font-dm-mono),monospace;text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px;display:block}.edit-form-group{flex-direction:column;gap:20px;margin-top:10px;display:flex}.action-buttons{gap:12px;margin-top:32px;display:flex}.action-buttons .submit-btn:last-child{flex:2}.delete-btn{color:#ef4444;background:#ef44441a;border:1px solid #ef444433;flex:1}.delete-btn:hover{color:#ef4444;background:#ef444433}.edit-card-preview{aspect-ratio:16/9;border-radius:var(--radius-lg);width:100%;box-shadow:var(--shadow-card);flex-direction:column;justify-content:space-between;margin-bottom:24px;padding:20px;transition:background-color .3s,color .3s;display:flex;position:relative;overflow:hidden}.edit-card-preview:before{opacity:.7;background:radial-gradient(circle at 100% 0,#ffffff47,#0000 35%)}.edit-card-preview:after,.edit-card-preview:before{content:"";border-radius:inherit;pointer-events:none;position:absolute;inset:0}.edit-card-preview:after{mix-blend-mode:overlay;background:linear-gradient(135deg,#ffffff52,#fff0 38%,#0000001f)}.edit-card-preview .card-top{z-index:1;justify-content:space-between;align-items:flex-start;gap:12px;display:flex;position:relative}.edit-card-preview .card-logo{letter-spacing:-.05em;font-size:2rem;font-weight:800;line-height:1}.edit-card-preview .card-icon{opacity:.84;flex-shrink:0;width:2rem;height:2rem}.edit-card-preview .card-bottom{z-index:1;position:relative}.edit-card-preview .card-name{letter-spacing:-.02em;margin-bottom:6px;font-size:1.05rem;font-weight:600}.edit-card-preview .card-meta{font-family:var(--font-dm-mono),monospace;opacity:.75;letter-spacing:.12em;text-transform:uppercase;font-size:.75rem}.sheet-header-left{gap:10px;min-width:0}.back-btn,.sheet-header-left{align-items:center;display:flex}.back-btn{color:var(--text-main);background:#ffffff0d;border:none;border-radius:999px;flex-shrink:0;justify-content:center;width:36px;height:36px;transition:background .2s,transform .2s}.back-btn:hover{background:#ffffff1a;transform:scale(.96)}.back-btn:active{transform:scale(.92)}.new-card-preview{width:100%;box-shadow:var(--shadow-card);border-radius:20px;align-items:center;gap:16px;margin-bottom:24px;padding:20px;transition:background-color .3s,color .3s;display:flex;position:relative;overflow:hidden}.new-card-preview:before{opacity:.7;background:radial-gradient(circle at 100% 0,#ffffff47,#0000 35%)}.new-card-preview:after,.new-card-preview:before{content:"";pointer-events:none;position:absolute;inset:0}.new-card-preview:after{border-radius:inherit;mix-blend-mode:overlay;background:linear-gradient(135deg,#ffffff52,#fff0 38%,#0000001f)}.preview-logo{letter-spacing:-.05em;z-index:1;opacity:.9;flex-shrink:0;font-size:1.75rem;font-weight:800;line-height:1;position:relative}.preview-info{z-index:1;flex-direction:column;gap:4px;min-width:0;display:flex;position:relative}.preview-name{letter-spacing:-.02em;white-space:nowrap;text-overflow:ellipsis;font-size:1.05rem;font-weight:600;overflow:hidden}.preview-barcode{font-family:var(--font-dm-mono),monospace;opacity:.7;letter-spacing:.12em;text-transform:uppercase;font-size:.75rem}.details-form{flex-direction:column;flex:1;display:flex;overflow-y:auto}.select-field{appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg width='12' height='8' viewBox='0 0 12 8' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1.5L6 6.5L11 1.5' stroke='%23a1a1aa' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-position:right 16px center;background-repeat:no-repeat;background-size:12px;padding-right:40px}.select-field option{background:var(--surface);color:var(--text-main)}.color-palette{flex-wrap:wrap;gap:10px;display:flex}.color-swatch{cursor:pointer;border:2px solid #0000;border-radius:999px;flex-shrink:0;width:36px;height:36px;transition:transform .2s,border-color .2s,box-shadow .2s;position:relative}.color-swatch:hover{transform:scale(1.1)}.color-swatch:active{transform:scale(.95)}.color-swatch.active{border-color:var(--text-main);box-shadow:0 0 0 3px var(--bg-base),0 0 0 5px var(--text-main);transform:scale(1.05)}.color-swatch.active:after{content:"";border-radius:inherit;background-image:url("data:image/svg+xml,%3Csvg width='14' height='14' viewBox='0 0 24 24' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M20 6L9 17L4 12' stroke='white' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-position:50%;background-repeat:no-repeat;background-size:14px;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.save-new-btn{width:100%;margin-top:24px}.icon-palette{flex-wrap:wrap;gap:8px;display:flex}.icon-swatch{width:44px;height:44px;color:var(--text-main);cursor:pointer;background:#ffffff0d;border:2px solid #0000;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;transition:transform .2s,border-color .2s,background .2s,box-shadow .2s;display:flex}.icon-swatch:hover{background:#ffffff1a;transform:scale(1.05)}.icon-swatch:active{transform:scale(.95)}.icon-swatch.active{border-color:var(--text-main);box-shadow:0 0 0 3px var(--bg-base),0 0 0 5px var(--text-main);background:#ffffff26}.offline-container{background:var(--bg-base);min-height:100dvh;color:var(--text-main);justify-content:center;align-items:center;padding:24px;display:flex}.offline-content{text-align:center;max-width:320px}.offline-icon{width:96px;height:96px;color:var(--text-muted);background:#ffffff0d;border-radius:24px;justify-content:center;align-items:center;margin:0 auto 24px;display:flex}.offline-title{letter-spacing:-.02em;margin-bottom:12px;font-size:1.5rem;font-weight:700}.offline-message{color:var(--text-muted);font-size:.95rem;line-height:1.6}.offline-button{background:var(--text-main);color:var(--bg-base);font-family:var(--font-bricolage),sans-serif;border:none;border-radius:12px;margin-top:24px;padding:14px 28px;font-size:1rem;font-weight:600;transition:transform .2s,background .2s}.offline-button:hover{background:#d4d4d8;transform:scale(.98)}.offline-button:active{transform:scale(.96)}.install-banner{z-index:50;width:100%;max-width:440px;animation:slideUpBanner .4s var(--easing-spring);background:linear-gradient(#18181b00,#18181bf2 30%);padding:16px 24px 32px;position:fixed;bottom:0;left:50%;transform:translate(-50%)}@keyframes slideUpBanner{0%{opacity:0;transform:translate(-50%)translateY(20px)}to{opacity:1;transform:translate(-50%)translateY(0)}}@keyframes slideDown{0%{opacity:0;transform:translate(-50%)translateY(-100%)}to{opacity:1;transform:translate(-50%)translateY(0)}}.install-card{background:var(--surface);border:1px solid #ffffff14;border-radius:20px;padding:20px;box-shadow:0 16px 40px #0006}.install-header{gap:14px;margin-bottom:16px}.install-header,.install-icon{align-items:center;display:flex}.install-icon{background:#ffffff0f;border-radius:14px;flex-shrink:0;justify-content:center;width:48px;height:48px}.install-header h3{letter-spacing:-.02em;font-size:1.05rem;font-weight:600}.install-header p{color:var(--text-muted);margin-top:4px;font-size:.85rem}.install-actions{gap:12px;display:flex}.install-btn{background:var(--text-main);color:var(--bg-base);font-family:var(--font-bricolage),sans-serif;border:none;border-radius:12px;flex:1;padding:14px 20px;font-size:.95rem;font-weight:600;transition:transform .2s,background .2s}.install-btn:hover{background:#d4d4d8;transform:scale(.98)}.install-btn:active{transform:scale(.96)}.install-dismiss{color:var(--text-muted);font-family:var(--font-bricolage),sans-serif;background:#ffffff0d;border:none;border-radius:12px;padding:14px 16px;font-size:.95rem;font-weight:500;transition:background .2s}.install-dismiss:hover{background:#ffffff1a}@media (hover:none){.card:hover{box-shadow:var(--shadow-card)}.add-btn:hover,.card:hover,.close-btn:hover,.submit-btn:hover{transform:none}}@media (max-width:420px){.app-header{padding:28px 18px 18px}.grid-container{gap:14px;padding:4px 18px 116px}.bottom-sheet{padding:28px 18px 32px}.brand-cluster{gap:12px}.brand-mark{border-radius:14px;width:40px;height:40px}.input-group{flex-direction:column}.submit-btn{width:100%}.action-buttons{flex-direction:column}.action-buttons .submit-btn:last-child{flex:1}}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-outline-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}@property --tw-backdrop-blur{syntax:"*";inherits:false}@property --tw-backdrop-brightness{syntax:"*";inherits:false}@property --tw-backdrop-contrast{syntax:"*";inherits:false}@property --tw-backdrop-grayscale{syntax:"*";inherits:false}@property --tw-backdrop-hue-rotate{syntax:"*";inherits:false}@property --tw-backdrop-invert{syntax:"*";inherits:false}@property --tw-backdrop-opacity{syntax:"*";inherits:false}@property --tw-backdrop-saturate{syntax:"*";inherits:false}@property --tw-backdrop-sepia{syntax:"*";inherits:false}@property --tw-ease{syntax:"*";inherits:false}