@import"https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@400;500;700&display=swap";@font-face{font-family:Montserrat;src:url(/fonts/Montserrat-VariableFont_wght.ttf) format("truetype-variations"),url(/fonts/Montserrat-VariableFont_wght.ttf) format("truetype");font-weight:100 900;font-style:normal;font-display:swap}:root{--surface-canvas: #05060F;--surface-raised: #0B0E1A;--surface-input: #141829;--surface-overlay: rgba(255, 255, 255, .04);--surface-divider: rgba(255, 255, 255, .08);--cyan-400: #22E4FF;--blue-500: #2D5BFF;--violet-500: #7C3AED;--magenta-500: #E5189A;--grad-brand: linear-gradient(135deg, #22E4FF 0%, #2D5BFF 38%, #7C3AED 70%, #E5189A 100%);--text-primary: #FFFFFF;--text-secondary: rgba(255, 255, 255, .66);--text-tertiary: rgba(255, 255, 255, .4);--text-on-brand: #050610;--danger: #FF5C7A;--success: #10E2A8;--font-display: "Montserrat", system-ui, sans-serif;--font-body: "Montserrat", system-ui, sans-serif;--font-mono: "JetBrains Mono", ui-monospace, monospace;--screen-pad: 20px;--nav-height: 76px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 20px;--radius-2xl: 24px;--radius-pill: 999px;--glow-cta: 0 16px 48px -10px rgba(45, 91, 255, .65), 0 4px 16px -4px rgba(124, 58, 237, .35);--ease-out: cubic-bezier(.2, .8, .2, 1);--dur: .2s}*{box-sizing:border-box}html,body,#root{height:100%}html,body{overflow-x:hidden}body{margin:0;background:var(--surface-canvas);color:var(--text-primary);font:400 15px/22px var(--font-body);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}h1{font:700 24px/30px var(--font-display);letter-spacing:-.02em;margin:0}h2{font:600 20px/26px var(--font-display);letter-spacing:-.02em;margin:0}h3{font:600 17px/22px var(--font-display);margin:0}p{margin:0;color:var(--text-secondary)}button{font-family:var(--font-body);cursor:pointer}input,select{font-family:var(--font-body)}.mono{font-family:var(--font-mono)}:root{--grad-cyan-blue: linear-gradient(150deg, #1F6E7B 0%, #123F5E 46%, #0A1E36 100%);--grad-blue-violet: linear-gradient(150deg, #33408A 0%, #20275A 48%, #10132E 100%);--grad-violet-magenta: linear-gradient(150deg, #6A2E70 0%, #41204C 50%, #1D0F2A 100%);--grad-cyan-magenta: linear-gradient(150deg, #39323F 0%, #22202B 48%, #0E0E16 100%);--grad-active: linear-gradient(135deg, rgba(34, 228, 255, .2), rgba(124, 58, 237, .24))}*{scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.16) transparent}::-webkit-scrollbar{width:7px;height:7px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#ffffff24;border-radius:999px;border:2px solid transparent;background-clip:padding-box}::-webkit-scrollbar-thumb:hover{background:#ffffff42;background-clip:padding-box}.app-shell{position:relative;width:100%;max-width:430px;height:100dvh;margin:0 auto;overflow:hidden;background:var(--surface-canvas)}.screen{position:relative;height:100%;overflow-y:auto}.screen::-webkit-scrollbar{width:0}.pad-bottom{padding-bottom:110px}.screen-bg{position:absolute;top:0;right:0;bottom:0;left:0;z-index:0;pointer-events:none;background:radial-gradient(circle at 85% 8%,rgba(34,228,255,.2),transparent 45%),radial-gradient(circle at 0% 95%,rgba(229,24,154,.16),transparent 50%),radial-gradient(circle at 50% 60%,rgba(124,58,237,.1),transparent 60%)}.eyebrow{font:500 10px/1 var(--font-body);letter-spacing:.08em;text-transform:uppercase;color:var(--text-tertiary)}.app-header{display:flex;align-items:center;justify-content:space-between;padding:8px 20px 4px}.app-header__brand{display:flex;align-items:center;gap:12px}.brand-logo{width:40px;height:40px}.brand-name{font:700 17px/1.1 var(--font-display);letter-spacing:-.02em}.brand-name span{color:var(--cyan-400)}.brand-greeting{font:400 12px/1.3 var(--font-body);color:var(--text-tertiary);margin-top:2px}.icon-btn{width:40px;height:40px;border-radius:999px;background:#ffffff0d;border:1px solid var(--surface-divider);color:var(--text-primary);display:grid;place-items:center;position:relative;cursor:pointer}.icon-btn--sm{width:36px;height:36px}.icon-btn--danger{background:#ff5c7a1a;border-color:#ff5c7a4d;color:var(--danger)}.badge-dot{position:absolute;top:7px;right:8px;width:8px;height:8px;border-radius:999px;background:var(--magenta-500);box-shadow:0 0 8px var(--magenta-500)}.screen-title{display:flex;align-items:baseline;justify-content:space-between;padding:14px 20px 10px}.screen-title h1{font:700 26px/1.1 var(--font-display);letter-spacing:-.02em}.screen-title__note{font:500 11px/1 var(--font-body);color:var(--text-tertiary);display:flex;align-items:center;gap:6px}.as-button{background:none;border:0;cursor:pointer;padding:6px 0}.section-head{display:flex;justify-content:space-between;align-items:baseline;padding:6px 20px 10px}.section-head__title{font:600 15px/1 var(--font-display)}.link{background:none;border:0;color:var(--cyan-400);font:500 12px/1 var(--font-body);cursor:pointer;padding:0}.stat-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:10px}.stat-grid__eyebrow{margin-bottom:10px}.stat-col{display:grid;gap:10px}.stat-tile{padding:14px 14px 16px;border-radius:16px;background:#ffffff0a;border:1px solid var(--surface-divider);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.stat-tile--accent{background:linear-gradient(180deg,#22e4ff29,#7c3aed1a);border-color:#22e4ff4d}.stat-tile__label{font:500 10px/1 var(--font-body);letter-spacing:.08em;text-transform:uppercase;color:var(--text-tertiary)}.stat-tile__value{font:700 22px/1.1 var(--font-display);margin-top:8px;letter-spacing:-.02em}.stat-tile__value .mono{font-family:var(--font-mono)}.stat-tile__value .unit{color:var(--text-secondary);font-size:13px;font-family:var(--font-display)}.stat-tile__sub{font:400 11px/1.4 var(--font-body);color:var(--text-tertiary);margin-top:4px}.btn{border:0;border-radius:999px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:8px;font-family:var(--font-display)}.btn--primary{background:var(--cyan-400);color:#050610;font-weight:600;font-size:14px;padding:14px 22px;letter-spacing:-.005em;box-shadow:inset 0 1px #ffffff8c,inset 0 -1px #05060f1a;transition:transform var(--dur) var(--ease-out),filter var(--dur) var(--ease-out)}.btn--primary:active{transform:scale(.98);filter:brightness(1.05)}.btn--lg{font-size:15px;padding:16px 26px}.btn--sm{font-size:13px;padding:11px 18px}.btn--full{width:100%}.btn:disabled{opacity:.4;cursor:default;box-shadow:none}.vcard{width:100%;max-width:320px;aspect-ratio:1.586 / 1;border-radius:22px;color:#fff;padding:18px;box-sizing:border-box;position:relative;overflow:hidden;box-shadow:0 14px 34px -18px #000000b3,inset 0 0 0 1px #ffffff0d;display:flex;flex-direction:column;justify-content:space-between}.vcard:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;background:linear-gradient(135deg,#ffffff1a,#fff0 34%,#0000001a)}.vcard--sm{max-width:260px}.vcard--lg{max-width:340px}.vcard--cyan-blue{background:var(--grad-cyan-blue)}.vcard--blue-violet{background:var(--grad-blue-violet)}.vcard--violet-magenta{background:var(--grad-violet-magenta)}.vcard--cyan-magenta{background:var(--grad-cyan-magenta)}.vcard__shine-1{position:absolute;inset:-45% -15% auto auto;width:75%;height:75%;background:radial-gradient(circle,rgba(255,255,255,.12),transparent 62%)}.vcard__shine-2{position:absolute;inset:auto -30% -40% auto;width:65%;height:65%;background:radial-gradient(circle,rgba(255,255,255,.05),transparent 62%)}.vcard__top{display:flex;justify-content:space-between;align-items:flex-start;position:relative}.vcard__name{font:500 10px/1 var(--font-display);letter-spacing:.08em;text-transform:uppercase;opacity:.85;white-space:nowrap}.vcard__chip{width:36px;height:26px;border-radius:5px;background:linear-gradient(135deg,#ffd27a,#c9a24b 50%,#8a6a22);opacity:.94;box-shadow:inset 0 0 0 1px #00000026}.vcard__number{font:600 17px/1 var(--font-mono);letter-spacing:.12em;position:relative;white-space:nowrap}.vcard__bottom{display:flex;justify-content:space-between;align-items:flex-end;position:relative}.vcard__exp{text-align:center}.vcard__meta-label{font:500 9px/1 var(--font-display);letter-spacing:.1em;text-transform:uppercase;opacity:.65;margin-bottom:4px}.vcard__meta-value{font:500 12px/1 var(--font-mono)}.vcard__brand{font:italic 700 20px/1 var(--font-display);letter-spacing:-.5px}.cards-strip{display:flex;gap:14px;padding:4px 20px 22px;overflow-x:auto;overscroll-behavior-x:contain;scroll-snap-type:x mandatory;scroll-padding-left:20px;scrollbar-width:none}.cards-strip::-webkit-scrollbar{height:0}.cards-strip>.vcard{flex:0 0 auto;width:clamp(248px,80%,320px);max-width:none;scroll-snap-align:start}.tx-row{display:flex;align-items:center;gap:12px;padding:12px 14px;background:#ffffff08;border:1px solid var(--surface-divider);border-radius:14px;width:100%;text-align:left;color:var(--text-primary);cursor:pointer}.tx-row__icon{width:40px;height:40px;border-radius:12px;flex:none;display:grid;place-items:center}.tx-row__icon--abonnement{background:linear-gradient(135deg,#22e4ff2e,#ffffff05);color:#22e4ff}.tx-row__icon--achat{background:linear-gradient(135deg,#7c3aed38,#ffffff05);color:#a78bfa}.tx-row__icon--service{background:linear-gradient(135deg,#e5189a38,#ffffff05);color:#f471b5}.tx-row__icon--autre{background:linear-gradient(135deg,#10e2a82e,#ffffff05);color:#10e2a8}.tx-row__body{flex:1;min-width:0}.tx-row__merchant{font:600 15px/1.2 var(--font-display)}.tx-row__sub{font:500 11px/1.3 var(--font-mono);color:var(--text-tertiary);margin-top:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tx-row__right{text-align:right;flex:none}.tx-row__amount{font:600 15px/1 var(--font-mono)}.tx-row__amount .cur{color:var(--text-tertiary);margin-left:4px;font-size:11px}.chip{margin-top:6px;display:inline-flex;padding:3px 8px;border-radius:999px;font:500 9px/1 var(--font-display);letter-spacing:.05em;text-transform:uppercase}.chip--abonnement{background:#22e4ff21;color:#22e4ff;border:1px solid rgba(34,228,255,.25)}.chip--achat{background:#7c3aed29;color:#a78bfa;border:1px solid rgba(124,58,237,.3)}.chip--service{background:#e5189a21;color:#f471b5;border:1px solid rgba(229,24,154,.3)}.chip--autre{background:#10e2a821;color:#10e2a8;border:1px solid rgba(16,226,168,.25)}.receipt{position:relative;overflow:hidden;padding:14px 16px 14px 20px;border-radius:14px;background:#ffffff08;border:1px solid var(--surface-divider)}.receipt:before{content:"";position:absolute;left:0;top:12px;bottom:12px;width:3px;border-radius:0 3px 3px 0;background:var(--cyan-400)}.receipt--abonnement:before{background:#22e4ff}.receipt--achat:before{background:#a78bfa}.receipt--service:before{background:#f471b5}.receipt--autre:before{background:#10e2a8}.receipt__label{margin-bottom:10px}.receipt__main{display:flex;align-items:baseline;justify-content:space-between;gap:12px}.receipt__merchant{font:600 17px/1.2 var(--font-display)}.receipt__amount{font:600 17px/1 var(--font-mono);white-space:nowrap}.receipt__amount .cur{color:var(--text-tertiary);font-size:12px;margin-left:4px}.receipt__sub{font:500 12px/1.3 var(--font-mono);color:var(--text-tertiary);margin-top:6px}.detail-sentence{position:relative;overflow:hidden;margin-bottom:16px;padding:16px 16px 14px 20px;border-radius:14px;background:#ffffff08;border:1px solid var(--surface-divider)}.detail-sentence__bar{position:absolute;left:0;top:14px;bottom:14px;width:3px;border-radius:0 3px 3px 0;background:var(--cyan-400)}.detail-sentence--abonnement .detail-sentence__bar{background:#22e4ff}.detail-sentence--achat .detail-sentence__bar{background:#a78bfa}.detail-sentence--service .detail-sentence__bar{background:#f471b5}.detail-sentence--autre .detail-sentence__bar{background:#10e2a8}.detail-sentence .eyebrow{margin-bottom:8px}.detail-sentence__text{font:500 16px/1.55 var(--font-body);color:var(--text-primary)}.detail-sentence__text b{color:var(--cyan-400);font-weight:600}.detail-list{display:flex;flex-direction:column;border:1px solid var(--surface-divider);border-radius:16px;overflow:hidden;margin-bottom:16px}.detail-row{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:13px 16px}.detail-row+.detail-row{border-top:1px solid var(--surface-divider)}.detail-row__label{font:500 11px/1 var(--font-body);letter-spacing:.06em;text-transform:uppercase;color:var(--text-tertiary);flex:none}.detail-row__value{font:500 14px/1.4 var(--font-body);color:var(--text-primary);text-align:right}.detail-row__value.mono{font-family:var(--font-mono)}.amount-reveal{display:inline-flex;align-items:center;gap:6px;background:none;border:0;padding:0;cursor:pointer;color:inherit;font:inherit}.amount-reveal svg{color:var(--text-tertiary)}.amount-reveal:active{opacity:.7}.btn-danger{width:100%;display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:14px;border-radius:999px;cursor:pointer;border:1px solid rgba(255,92,122,.3);background:#ff5c7a1a;color:var(--danger);font:600 14px/1 var(--font-display)}.btn-danger:disabled{opacity:.5;cursor:default}.btn-ghost{flex:1;padding:14px;border-radius:999px;cursor:pointer;border:1px solid var(--surface-divider);background:transparent;color:var(--text-secondary);font:600 14px/1 var(--font-display)}.btn-ghost:disabled{opacity:.5;cursor:default}.confirm-sheet{text-align:center}.confirm-text{color:var(--text-secondary);font:400 14px/1.5 var(--font-body);margin:10px 0 20px}.confirm-actions{display:flex;gap:12px}.confirm-actions .btn-danger{flex:1}.list{display:flex;flex-direction:column;gap:10px;padding:0 20px}.list-meta{display:flex;justify-content:space-between;align-items:baseline;padding:6px 20px 8px}.list-meta__total{font:500 12px/1 var(--font-mono);color:var(--text-secondary)}.empty{padding:36px 20px;text-align:center;color:var(--text-tertiary);font:400 13px/1.5 var(--font-body);display:flex;flex-direction:column;align-items:center;gap:10px}.search-bar{display:flex;align-items:center;gap:10px;background:var(--surface-input);border:1px solid var(--surface-divider);border-radius:14px;padding:12px 14px;color:var(--text-tertiary)}.search-bar input{flex:1;min-width:0;background:none;border:0;outline:0;color:var(--text-primary);font:500 14px/1 var(--font-body)}.search-clear{background:none;border:0;color:var(--text-tertiary);cursor:pointer;display:grid;place-items:center}.segmented{display:flex;padding:4px;gap:4px;background:var(--surface-raised);border:1px solid rgba(255,255,255,.06);border-radius:999px}.segmented__item{flex:1;padding:9px 0;border:0;cursor:pointer;background:transparent;color:var(--text-secondary);font:500 12px/1 var(--font-body);border-radius:999px}.segmented__item--active{background:var(--grad-active);color:var(--text-primary);box-shadow:inset 0 0 0 1px #22e4ff59}.cards-list{display:flex;flex-direction:column;gap:14px}.card-block{display:flex;flex-direction:column;gap:8px}.card-block--button{width:100%;background:none;border:0;padding:0;cursor:pointer;color:inherit;text-align:left}.card-block__chev{color:var(--text-tertiary);display:grid;place-items:center;flex:none}.card-block__center{width:100%;display:flex;justify-content:center}.card-block__row{display:flex;justify-content:space-between;align-items:center;padding:0 4px}.card-block__name{font:600 15px/1.2 var(--font-display)}.card-block__sub{font:500 11px/1.3 var(--font-mono);color:var(--text-tertiary);margin-top:3px}.card-actions{display:flex;gap:8px}.add-card-btn{margin-top:6px;align-self:center;width:100%;max-width:340px;aspect-ratio:1.586 / 1;border-radius:22px;border:1.5px dashed rgba(255,255,255,.18);background:#ffffff05;color:var(--text-secondary);display:flex;align-items:center;justify-content:center;gap:10px;font:600 14px/1 var(--font-display);cursor:pointer}.add-card-preview{display:flex;justify-content:center;margin-bottom:18px;width:100%}.reveal-toggle{display:flex;width:fit-content;align-items:center;gap:8px;margin:0 auto 16px;padding:9px 16px;border-radius:999px;cursor:pointer;background:#ffffff0d;border:1px solid var(--surface-divider);color:var(--text-secondary);font:500 13px/1 var(--font-body)}.grad-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}.grad-swatch{height:40px;border-radius:12px;border:1px solid var(--surface-divider);cursor:pointer}.grad-swatch--active{box-shadow:0 0 0 2px var(--surface-canvas),0 0 0 4px var(--cyan-400)}.profile-card{margin:0 20px 18px;padding:16px;border-radius:16px;background:#ffffff0a;border:1px solid var(--surface-divider);display:flex;align-items:center;gap:14px}.avatar{width:52px;height:52px;border-radius:999px;background:var(--surface-input);border:1px solid var(--surface-divider);display:grid;place-items:center;font:700 18px/1 var(--font-display);color:var(--cyan-400)}.profile-card__name{font:600 15px/1.2 var(--font-display)}.profile-card__mail{font:400 12px/1.3 var(--font-body);color:var(--text-tertiary);margin-top:2px}.profile-card__body{flex:1}.settings-group{padding:0 20px 16px}.settings-group__title{padding:0 4px 8px}.settings-card{background:#ffffff08;border:1px solid var(--surface-divider);border-radius:16px;overflow:hidden}.settings-row{display:flex;align-items:center;gap:12px;padding:14px 16px;width:100%}.settings-row+.settings-row{border-top:1px solid var(--surface-divider)}.settings-row--button{background:transparent;border:0;cursor:pointer;text-align:left;font:inherit;color:inherit}.settings-row--button:active{background:#ffffff08}.settings-row__icon{width:34px;height:34px;border-radius:10px;background:#ffffff0d;border:1px solid var(--surface-divider);color:var(--cyan-400);display:grid;place-items:center;flex:none}.settings-row__icon--danger{background:#ff5c7a1f;border-color:#ff5c7a40;color:var(--danger)}.settings-row__label{flex:1;font:500 14px/1.2 var(--font-body);color:var(--text-primary)}.settings-row__label--danger{color:var(--danger)}.settings-row__value{font:500 12px/1 var(--font-body);color:var(--text-tertiary)}.settings-row__chev{color:var(--text-tertiary);display:grid;place-items:center}.app-version{padding:8px 20px 20px;text-align:center;font:400 11px/1.4 var(--font-body);color:var(--text-tertiary)}.block{padding:0 20px 18px}.block--tight{padding:14px 20px 18px}.search-block{display:flex;flex-direction:column;gap:12px;padding-top:0}.auth-screen{position:relative;width:100%;min-height:100dvh;overflow:hidden;background:var(--surface-canvas);display:flex}.auth{position:relative;z-index:1;flex:1;min-height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 24px;text-align:center}.auth__logo{width:56px;height:56px;margin-bottom:18px}.auth__title{font:700 26px/1.1 var(--font-display);letter-spacing:-.02em}.auth__title span{color:var(--cyan-400)}.auth__subtitle{color:var(--text-tertiary);font:400 13px/1.5 var(--font-body);margin-top:8px}.auth__form{width:100%;max-width:360px;display:flex;flex-direction:column;gap:14px;margin-top:28px;text-align:left}.auth__form .btn{margin-top:4px}.auth__error{font:500 13px/1.4 var(--font-body);color:var(--danger);background:#ff5c7a1a;border:1px solid rgba(255,92,122,.3);border-radius:12px;padding:10px 12px}.auth__info{font:500 13px/1.4 var(--font-body);color:var(--success);background:#10e2a81a;border:1px solid rgba(16,226,168,.3);border-radius:12px;padding:10px 12px}.auth__switch{margin-top:22px;background:none;border:0;color:var(--cyan-400);font:500 13px/1 var(--font-body);cursor:pointer}.field-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.field-grid>*{min-width:0}.demo-banner{margin:0 20px 12px;padding:9px 12px;border-radius:10px;background:#ffb0201a;border:1px solid rgba(255,176,32,.3);color:#ffb020;font:500 11px/1.4 var(--font-body);text-align:center}.account-mail{font:500 12px/1 var(--font-mono);color:var(--text-tertiary)}.splash{position:relative;z-index:1;min-height:100%;display:grid;place-items:center;color:var(--text-tertiary);font:500 13px/1 var(--font-body)}.bottom-nav{position:absolute;bottom:14px;left:16px;right:16px;z-index:5;background:#0b0e1ac7;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--surface-divider);border-radius:24px;padding:8px 6px;display:grid;grid-template-columns:repeat(4,1fr);gap:2px;box-shadow:0 18px 50px -12px #000000b3}.nav-item{position:relative;background:transparent;border:0;padding:10px 4px;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:4px;color:var(--text-tertiary);font:500 10px/1 var(--font-body);letter-spacing:.04em;text-transform:uppercase;border-radius:16px}.nav-item--active{color:var(--cyan-400)}.nav-item__indicator{position:absolute;top:0;left:32%;right:32%;height:2px;border-radius:0 0 2px 2px;background:var(--cyan-400)}.sheet-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;display:flex;flex-direction:column;align-items:center;justify-content:flex-end}.sheet-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:#0000008c;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.sheet{position:relative;width:100%;max-width:430px;background:var(--surface-raised);border-radius:24px 24px 0 0;border-top:1px solid var(--surface-divider);padding:14px 20px 24px;max-height:92%;overflow-y:auto;overflow-x:hidden;box-shadow:0 -20px 60px -10px #000000b3;animation:sheet-up var(--dur) var(--ease-out)}.sheet__form{min-width:0}.sheet__form>*{min-width:0}@keyframes sheet-up{0%{transform:translateY(40px)}to{transform:none}}.sheet__handle{width:40px;height:4px;border-radius:999px;background:#ffffff2e;margin:0 auto 14px}.sheet__head{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.sheet__title{font:700 20px/1.1 var(--font-display);letter-spacing:-.02em}.sheet__form{display:flex;flex-direction:column;gap:14px}.field{display:flex;flex-direction:column;gap:6px}.field__label{font:500 10px/1 var(--font-body);letter-spacing:.08em;text-transform:uppercase;color:var(--text-tertiary)}.field__hint{font:400 11px/1.3 var(--font-body);color:var(--text-tertiary)}.input{display:flex;align-items:center;gap:8px;background:var(--surface-input);border:1px solid var(--surface-divider);border-radius:12px;padding:12px 14px}.input:focus-within{border-color:#22e4ff73}.input input{flex:1;min-width:0;background:none;border:0;outline:0;color:var(--text-primary);font:500 15px/1 var(--font-body)}.input input.mono{font-family:var(--font-mono)}.input--readonly{color:var(--text-tertiary);font:500 15px/1 var(--font-body)}.input__affix{color:var(--text-tertiary);font:500 14px/1 var(--font-body)}.select-btn{display:flex;align-items:center;justify-content:space-between;background:var(--surface-input);border:1px solid var(--surface-divider);border-radius:12px;padding:12px 14px;color:var(--text-primary);font:500 15px/1 var(--font-body);width:100%;cursor:pointer;text-align:left}.grid-2{display:grid;grid-template-columns:2fr 1fr;gap:10px}.grid-2>*,.stat-grid>*,.cat-grid>*,.grad-grid>*{min-width:0}.cat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:6px}.cat-btn{padding:10px 4px;border-radius:10px;background:var(--surface-input);border:1px solid var(--surface-divider);color:var(--text-secondary);font:500 11px/1.2 var(--font-body);cursor:pointer;text-transform:capitalize}.cat-btn--active{background:linear-gradient(135deg,#22e4ff2e,#7c3aed38);border-color:#22e4ff73;color:var(--text-primary)}.card-pick-row{display:flex;gap:10px;overflow-x:auto;padding-bottom:4px;scrollbar-width:none}.card-pick-row::-webkit-scrollbar{height:0}.card-pick{flex:none;padding:10px 12px;border-radius:12px;cursor:pointer;background:var(--surface-input);border:1px solid var(--surface-divider);color:var(--text-secondary);font:600 12px/1.2 var(--font-display);display:flex;flex-direction:column;gap:4px;align-items:flex-start}.card-pick span.num{font:500 11px/1 var(--font-mono);opacity:.85}.card-pick--active{color:#fff;border-color:#ffffff2e}.card-pick--active.vcard--cyan-blue{background:var(--grad-cyan-blue)}.card-pick--active.vcard--blue-violet{background:var(--grad-blue-violet)}.card-pick--active.vcard--violet-magenta{background:var(--grad-violet-magenta)}.card-pick--active.vcard--cyan-magenta{background:var(--grad-cyan-magenta)}.sidebar{display:none}.avatar--sm{width:36px;height:36px;font-size:13px}@media(min-width:900px){.app-shell{max-width:none;width:100%;display:flex;flex-direction:row}.sidebar{position:relative;z-index:3;flex:none;width:268px;height:100%;display:flex;flex-direction:column;gap:6px;padding:22px 16px;background:#0b0e1ab8;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-right:1px solid var(--surface-divider)}.sidebar__brand{display:flex;align-items:center;gap:12px;padding:4px 8px 18px;font:700 18px/1 var(--font-display);letter-spacing:-.02em}.sidebar__brand img{width:34px;height:34px}.sidebar__brand b{color:var(--cyan-400);font-weight:700}.sidebar__cta{display:inline-flex;align-items:center;justify-content:center;gap:8px;margin:0 4px 16px;padding:13px 16px;border:0;border-radius:14px;cursor:pointer;background:var(--cyan-400);color:#050610;font:600 14px/1 var(--font-display);box-shadow:inset 0 1px #ffffff80}.sidebar__cta:active{transform:scale(.98)}.sidebar__nav{display:flex;flex-direction:column;gap:4px}.sidebar__item{display:flex;align-items:center;gap:12px;width:100%;padding:12px 14px;border:0;border-radius:12px;cursor:pointer;background:transparent;color:var(--text-secondary);font:500 14px/1 var(--font-body);text-align:left;transition:background var(--dur) var(--ease-out),color var(--dur) var(--ease-out)}.sidebar__item:hover{background:#ffffff0a;color:var(--text-primary)}.sidebar__item.is-active{background:var(--grad-active);color:var(--text-primary);box-shadow:inset 0 0 0 1px #22e4ff4d}.sidebar__item.is-active svg{color:var(--cyan-400)}.sidebar__foot{margin-top:auto;display:flex;flex-direction:column;gap:10px;padding-top:16px;border-top:1px solid var(--surface-divider)}.sidebar__user{display:flex;align-items:center;gap:10px;min-width:0}.sidebar__user-mail{font:500 12px/1.2 var(--font-mono);color:var(--text-tertiary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar__logout{padding:10px;border-radius:10px;cursor:pointer;border:1px solid var(--surface-divider);background:transparent;color:var(--text-secondary);font:500 12px/1 var(--font-body)}.sidebar__logout:hover{color:var(--danger);border-color:#ff5c7a4d}.bottom-nav{display:none}.screen{flex:1}.screen.pad-bottom{padding-bottom:24px}.screen>*{max-width:860px;margin:0 auto;padding-top:8px}.app-header,.home-cta{display:none}.cards-list{display:grid;grid-template-columns:repeat(2,1fr);gap:18px 18px;align-items:start}.cards-list .add-card-btn{grid-column:1 / -1;justify-self:center;max-width:340px}.cards-list .empty{grid-column:1 / -1}.sheet-overlay{justify-content:center}.sheet{border-radius:20px;max-height:86vh}}
