:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400}body{margin:0;min-width:320px;min-height:100vh;background-color:#fff;color:#213547}.login-container{min-height:100vh;display:flex;flex-direction:column;background:linear-gradient(135deg,#667eea,#764ba2);padding:0;position:relative;overflow:hidden}.login-container:before,.login-container:after{content:"";position:absolute;border-radius:50%;background:#ffffff1a}.login-container:before{width:300px;height:300px;top:-100px;right:-100px}.login-container:after{width:200px;height:200px;bottom:-50px;left:-50px}.login-card{background:#fff;border-radius:30px 30px 0 0;box-shadow:0 -10px 40px #0003;padding:40px 24px 32px;width:100%;max-width:500px;margin:auto auto 0;position:relative;z-index:1}.login-header{text-align:center;margin-bottom:32px}.login-header h1{color:#1a1a1a;font-size:28px;font-weight:700;margin-bottom:8px;letter-spacing:-.5px}.login-header p{color:#666;font-size:15px;font-weight:400}.error-message{background-color:#fee;border-left:4px solid #ef4444;color:#991b1b;padding:14px 16px;border-radius:12px;margin-bottom:20px;font-size:14px;font-weight:500}.login-form{display:flex;flex-direction:column;gap:24px}.form-group{display:flex;flex-direction:column}.form-group label{color:#1a1a1a;font-weight:600;margin-bottom:10px;font-size:15px}.form-group input{padding:16px 18px;border:2px solid #e5e7eb;border-radius:14px;font-size:16px;transition:all .2s;background:#f9fafb}.form-group input:focus{outline:none;border-color:#667eea;background:#fff;box-shadow:0 0 0 4px #667eea1a}.captcha-container{display:flex;align-items:center;gap:12px;margin-bottom:12px}.captcha-image{height:50px;border:2px solid #e5e7eb;border-radius:12px;flex:1;background:#f9fafb}.refresh-captcha{padding:12px 18px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:12px;cursor:pointer;font-size:22px;transition:all .2s;box-shadow:0 4px 12px #667eea4d}.refresh-captcha:active{transform:scale(.95)}.login-button{padding:18px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:16px;font-size:17px;font-weight:700;cursor:pointer;transition:all .3s;margin-top:8px;box-shadow:0 8px 20px #667eea66;letter-spacing:.5px}.login-button:active:not(:disabled){transform:translateY(2px);box-shadow:0 4px 12px #667eea4d}.login-button:disabled{opacity:.6;cursor:not-allowed}@media(max-width:768px){.login-card{min-height:60vh;padding:32px 20px 24px}.login-header h1{font-size:24px}.form-group input{font-size:16px}}.dashboard-container{min-height:100vh;background:#f8f9fb;padding-bottom:90px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif}.dashboard-header{background:transparent;color:#1a1d29;padding:12px 20px 0;position:relative;z-index:50}.header-content{max-width:500px;margin:0 auto}.header-top{display:flex;justify-content:space-between;align-items:center;gap:16px;margin-bottom:12px}.greeting{display:flex;align-items:center;gap:12px;flex:1}.profile-picture{width:52px;height:52px;border-radius:50%;background:linear-gradient(145deg,#0f172a,#1f2937);display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:700;color:#fff;flex-shrink:0;box-shadow:0 6px 18px #0000002e}.profile-text{display:flex;flex-direction:column;gap:2px}.hello{font-size:16px;font-weight:900;text-transform:uppercase;letter-spacing:.8px;color:#111827}.profile-name{font-size:18px;font-weight:800;color:#111827;letter-spacing:-.3px}.icon-button{background:transparent;border:1px solid #d1d5db;border-radius:12px;padding:8px 10px;color:#111827;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;flex-shrink:0}.icon-button:hover{box-shadow:0 6px 18px #00000014;transform:translateY(-1px)}.icon-button:active{transform:scale(.95)}.back-button{min-width:64px;font-weight:700;background:#fff}.menu-button{background:transparent;border:none;padding:8px;cursor:pointer;transition:all .2s;flex-shrink:0}.burger-button{border:1px solid #d1d5db;border-radius:12px;padding:10px;background:#fff}.hamburger{display:flex;flex-direction:column;gap:5px;width:24px}.hamburger span{display:block;width:100%;height:2.5px;background:#0f172a;border-radius:3px;transition:all .3s}.dropdown-menu{position:absolute;top:100%;right:20px;background:#fff;border-radius:16px;box-shadow:0 8px 24px #00000026;overflow:hidden;margin-top:8px;min-width:240px;animation:slideDown .3s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.mode-toggle-menu{background:#fff;padding:12px 16px}.mode-toggle-menu .toggle-label{color:#1a1a1a}.mode-toggle-menu .mode-info{color:#6b7280;margin-left:68px}.menu-divider{height:1px;background:#e5e7eb;margin:0}.menu-item{width:100%;padding:14px 16px;background:#fff;border:none;text-align:left;color:#ef4444;font-weight:600;font-size:15px;cursor:pointer;transition:background .2s}.menu-item:hover{background:#fef2f2}.menu-item:active{background:#fee2e2}.dashboard-header h1{margin:0 0 16px;font-size:24px;font-weight:700;letter-spacing:-.5px}.header-controls{display:flex;flex-direction:column;gap:12px}.mode-toggle{background:#fff;border-radius:16px;padding:12px 16px;border:1px solid #e5e7eb}.toggle-label{display:flex;align-items:center;gap:12px;cursor:pointer;-webkit-user-select:none;user-select:none}.toggle-checkbox{display:none}.toggle-slider{position:relative;width:56px;height:30px;background-color:#ffffff4d;border-radius:15px;transition:background-color .3s;flex-shrink:0}.toggle-slider:before{content:"";position:absolute;width:24px;height:24px;left:3px;top:3px;background-color:#fff;border-radius:50%;transition:transform .3s;box-shadow:0 2px 4px #0003}.toggle-checkbox:checked+.toggle-slider{background-color:#10b981}.toggle-checkbox:checked+.toggle-slider:before{transform:translate(26px)}.toggle-text{font-weight:600;font-size:15px;flex:1}.mode-info{color:#4b5563;font-size:12px;margin-top:6px;margin-left:68px}.user-info{display:flex;align-items:center;justify-content:space-between;gap:12px;font-size:14px}.logout-button{padding:8px 16px;background-color:#0f172a;color:#fff;border:none;border-radius:12px;cursor:pointer;transition:all .2s;font-weight:600;font-size:14px}.header-top-back{justify-content:flex-start;gap:12px}.page-label{font-weight:800;font-size:18px;color:#111827}.logout-button:active{transform:scale(.95);background-color:#ffffff4d}.optional-badge{color:#10b981;font-size:12px;font-weight:600}.mobile-prompt{position:fixed;inset:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.mobile-prompt-content{background:#fff;border-radius:24px;padding:32px 24px;max-width:400px;box-shadow:0 20px 60px #0000004d;animation:slideUp .3s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.mobile-prompt-content h3{margin-bottom:16px;color:#1a1a1a;font-size:22px;font-weight:700}.mobile-prompt-content p{color:#666;margin-bottom:16px}.mobile-prompt-content ul{margin:16px 0;padding-left:20px;color:#666}.mobile-prompt-content li{margin-bottom:12px;line-height:1.5}.close-prompt{width:100%;padding:16px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:14px;font-size:16px;font-weight:700;cursor:pointer;box-shadow:0 4px 12px #667eea66}.close-prompt:active{transform:scale(.98)}.dashboard-content{max-width:500px;margin:0 auto;padding:20px}.tabs{position:fixed;bottom:0;left:0;right:0;background:#1a1d29;display:flex;justify-content:space-around;align-items:center;padding:12px 20px calc(12px + env(safe-area-inset-bottom));box-shadow:0 -8px 32px #0003;z-index:100;border-top:1px solid rgba(255,255,255,.05)}.tab{flex:1;padding:12px 8px;background:none;border:none;color:#6b7280;font-size:11px;font-weight:500;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);border-radius:16px;display:flex;flex-direction:column;align-items:center;gap:6px;position:relative}.tab.active{color:#fff}.tab.active .tab-icon-wrapper{background:linear-gradient(135deg,#ff6b35,#ff8c42);box-shadow:0 8px 20px #ff6b3566}.tab.active .tab-icon{stroke:#fff;transform:scale(1.1)}.tab:active{transform:scale(.95)}.tab-icon-wrapper{width:48px;height:48px;border-radius:14px;background:transparent;display:flex;align-items:center;justify-content:center;transition:all .3s cubic-bezier(.4,0,.2,1)}.tab-icon{width:24px;height:24px;stroke:#6b7280;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;fill:none;transition:all .3s cubic-bezier(.4,0,.2,1)}.tab-content{background:transparent;padding:0;margin-bottom:20px}.home-section{animation:fadeIn .3s ease-out}.balance-card{background:linear-gradient(135deg,#ff6b35,#ff8c42);border-radius:24px;padding:28px;margin-bottom:24px;color:#fff;box-shadow:0 8px 32px #ff6b354d}.balance-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.balance-label{font-size:13px;font-weight:500;opacity:.9;text-transform:uppercase;letter-spacing:.5px}.balance-icon{width:24px;height:24px;stroke:#fff;opacity:.8}.balance-amount{font-size:36px;font-weight:700;letter-spacing:-1.5px;margin-bottom:16px;line-height:1}.balance-footer{display:flex;justify-content:space-between;align-items:center;padding-top:16px;border-top:1px solid rgba(255,255,255,.2)}.balance-transactions{font-size:13px;font-weight:500;opacity:.9}.balance-change{font-size:13px;font-weight:600;background:#fff3;padding:4px 12px;border-radius:12px}.quick-actions{margin-bottom:24px}.action-button-large{width:100%;background:linear-gradient(135deg,#ff6b35,#ff8c42);border:none;border-radius:20px;padding:24px;margin-bottom:12px;display:flex;align-items:center;gap:16px;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 8px 24px #ff6b3559}.action-button-large:active{transform:translateY(2px);box-shadow:0 4px 16px #ff6b3540}.action-button-large span{font-size:18px;font-weight:600;color:#fff;letter-spacing:-.3px}.action-button-icon{width:56px;height:56px;background:#fff3;border-radius:16px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.action-button-icon svg{width:28px;height:28px;stroke:#fff;stroke-width:2.5}.action-grid-small{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.action-button-small{background:#fff;border:none;border-radius:20px;padding:24px 16px;display:flex;flex-direction:column;align-items:center;gap:12px;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 20px #0000000a}.action-button-small:active{transform:scale(.96);box-shadow:0 8px 30px #ff6b3526}.action-button-small svg{width:28px;height:28px;stroke:#ff6b35;stroke-width:2}.action-button-small span{font-size:14px;font-weight:600;color:#1a1d29;letter-spacing:-.2px}.recent-section{margin-bottom:24px}.recent-section h3{font-size:18px;font-weight:700;color:#1a1d29;margin-bottom:16px;letter-spacing:-.5px}.activity-card{background:#fff;border-radius:20px;padding:20px;display:flex;align-items:center;gap:16px;box-shadow:0 4px 20px #0000000a}.activity-icon{width:48px;height:48px;background:linear-gradient(135deg,#fff5f2,#ffe8df);border-radius:14px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.activity-icon svg{width:24px;height:24px;stroke:#ff6b35;stroke-width:2}.activity-content{flex:1}.activity-title{font-size:15px;font-weight:600;color:#1a1d29;margin-bottom:4px;letter-spacing:-.2px}.activity-subtitle{font-size:13px;font-weight:500;color:#9ca3af}.activity-amount{text-align:right}.activity-value{font-size:16px;font-weight:700;color:#1a1d29;margin-bottom:4px;letter-spacing:-.5px}.activity-date{font-size:12px;font-weight:500;color:#9ca3af}.transaction-card{background:#fff;border-radius:24px;padding:24px;box-shadow:0 4px 20px #0000000a;border:none}.transaction-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;padding-bottom:16px;border-bottom:1px solid #f3f4f6}.transaction-type{font-weight:600;background:linear-gradient(135deg,#ff6b35,#ff8c42);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-size:16px}.transaction-amount{font-weight:700;color:#1a1d29;font-size:20px;letter-spacing:-.5px}.transaction-details{display:flex;flex-direction:column;gap:10px}.transaction-row{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}.transaction-row .label{color:#6b7280;font-weight:600;font-size:13px;min-width:80px}.transaction-row .value{color:#1a1a1a;font-weight:600;font-size:13px;text-align:right;word-break:break-all}.transaction-row .token-value{font-family:Courier New,monospace;background:linear-gradient(135deg,#ff6b35,#ff8c42);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-weight:700;letter-spacing:.5px;font-size:12px}.buy-tokens-section,.manage-meter-section,.history-section{animation:fadeIn .3s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.buy-tokens-section h2,.manage-meter-section h2,.history-section h2{font-size:24px;font-weight:700;color:#1a1a1a;margin-bottom:8px;letter-spacing:-.5px}.section-description{color:#666;margin-bottom:24px;font-size:15px;line-height:1.5}.token-form,.meter-input{background:#fff;border-radius:24px;padding:24px;box-shadow:0 4px 20px #0000000a;margin-bottom:20px;border:none}.form-group{margin-bottom:20px}.form-group:last-child{margin-bottom:0}.form-group label{display:block;color:#1a1a1a;font-weight:600;margin-bottom:10px;font-size:15px}.form-group input{width:100%;padding:16px 18px;border:2px solid #e5e7eb;border-radius:16px;font-size:16px;transition:all .3s cubic-bezier(.4,0,.2,1);background:#f9fafb;box-sizing:border-box;font-weight:500}.form-group input:focus{outline:none;border-color:#ff6b35;background:#fff;box-shadow:0 0 0 4px #ff6b3514}.form-group input:disabled{opacity:.5;cursor:not-allowed}.form-group textarea,.form-group select{width:100%;padding:14px 16px;border:2px solid #e5e7eb;border-radius:16px;font-size:15px;transition:all .25s ease;background:linear-gradient(180deg,#fff,#f8fafc);box-shadow:0 4px 14px #00000008;box-sizing:border-box}.form-group select{appearance:none;background-image:linear-gradient(45deg,transparent 50%,#111827 50%),linear-gradient(135deg,#111827 50%,transparent 50%);background-position:calc(100% - 18px) calc(50% - 3px),calc(100% - 12px) calc(50% - 3px);background-size:6px 6px,6px 6px;background-repeat:no-repeat}.form-group textarea:focus,.form-group select:focus{outline:none;border-color:#111827;box-shadow:0 10px 28px #00000014;transform:translateY(-1px)}.form-group small{color:#9ca3af;font-size:13px;display:block;margin-top:6px}.action-button{width:100%;padding:18px;border:none;border-radius:20px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);letter-spacing:-.2px}.action-button.primary{background:linear-gradient(135deg,#ff6b35,#ff8c42);color:#fff;box-shadow:0 8px 24px #ff6b3559}.action-button.primary:active:not(:disabled){transform:translateY(1px);box-shadow:0 4px 16px #ff6b3540}.action-button.secondary{background:#fff;color:#1a1d29;border:2px solid #e5e7eb;box-shadow:0 2px 8px #0000000a}.action-button.secondary:active:not(:disabled){background:#f9fafb;transform:translateY(1px)}.action-button:disabled{opacity:.5;cursor:not-allowed}.action-buttons{display:flex;flex-direction:column;gap:12px}.error-message{background:#fee2e2;border-left:4px solid #ef4444;color:#991b1b;padding:16px;border-radius:14px;margin-bottom:20px;font-size:14px;font-weight:500}.success-message{background:#d1fae5;border-left:4px solid #10b981;color:#065f46;padding:16px;border-radius:14px;margin-bottom:20px;font-size:14px;font-weight:500}.token-result{background:#fff;border-radius:20px;padding:24px;box-shadow:0 4px 20px #667eea26;margin-top:24px;border:2px solid #667eea}.token-result h3{color:#667eea;margin-bottom:20px;font-size:20px;font-weight:700}.token-details{display:flex;flex-direction:column;gap:12px;margin-bottom:20px}.token-item{display:flex;justify-content:space-between;align-items:flex-start;padding:14px;background:#f9fafb;border-radius:12px;gap:12px}.token-item .label{color:#6b7280;font-weight:600;font-size:14px;min-width:100px}.token-item .value{color:#1a1a1a;font-weight:600;font-size:14px;text-align:right;word-break:break-all}.token-code{font-family:Courier New,monospace;font-size:16px!important;font-weight:700!important;color:#667eea!important;letter-spacing:1px}.token-instructions{background:#eff6ff;padding:20px;border-radius:14px;border:1px solid #dbeafe}.token-instructions p{color:#1e40af;font-weight:600;margin-bottom:12px;font-size:15px}.token-instructions ol{margin:0;padding-left:20px;color:#374151}.token-instructions li{margin-bottom:10px;line-height:1.5}.history-summary-card{background:linear-gradient(135deg,#ff6b35,#ff8c42);border-radius:24px;padding:24px;margin-bottom:24px;color:#fff;box-shadow:0 8px 32px #ff6b354d}.summary-header{display:flex;align-items:center;gap:16px;margin-bottom:24px}.summary-icon{width:48px;height:48px;background:#fff3;border-radius:16px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.summary-icon svg{width:26px;height:26px;stroke-width:2.5}.summary-title h3{font-size:20px;font-weight:700;margin:0 0 4px;letter-spacing:-.5px}.summary-title p{font-size:14px;margin:0;opacity:.9;font-weight:400}.summary-stats{display:flex;justify-content:space-between;align-items:center;background:#ffffff26;border-radius:16px;padding:16px 20px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.summary-stat-item{flex:1;text-align:center}.summary-stat-value{font-size:20px;font-weight:700;margin-bottom:4px;letter-spacing:-.3px}.summary-stat-label{font-size:12px;opacity:.9;font-weight:500}.summary-stat-divider{width:1px;height:40px;background:#ffffff4d;margin:0 12px}.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:24px}.stat-card{background:#fff;border-radius:16px;padding:16px 12px;text-align:center;box-shadow:0 2px 8px #0000000f;border:1px solid #e5e7eb}.stat-value{font-size:20px;font-weight:700;color:#667eea;margin-bottom:4px}.stat-label{font-size:12px;color:#6b7280;font-weight:500}.empty-history{text-align:center;padding:60px 20px;color:#9ca3af}.empty-history p:first-child{font-size:48px;margin-bottom:12px}.empty-history p:last-child{font-size:15px}.history-list{display:flex;flex-direction:column;gap:12px}.history-item{background:#fff;border-radius:20px;padding:20px;box-shadow:0 4px 12px #00000014;border:1px solid #e5e7eb;transition:all .2s ease}.history-item:hover{transform:translateY(-2px);box-shadow:0 6px 16px #0000001f}.history-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;padding-bottom:12px;border-bottom:2px solid #f3f4f6}.history-type{font-weight:700;color:#667eea;font-size:16px;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.history-date{color:#9ca3af;font-size:13px;font-weight:500}.history-details{display:flex;flex-direction:column;gap:10px}.history-row{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}.history-row .label{color:#6b7280;font-weight:600;font-size:14px;min-width:80px}.history-row .value{color:#1a1a1a;font-weight:600;font-size:14px;text-align:right;word-break:break-all}.history-row .token-value{font-family:Courier New,monospace;color:#667eea;font-weight:700;letter-spacing:.5px;font-size:13px}.history-actions{margin-top:24px;display:flex;justify-content:center}.history-actions .action-button.secondary{background:#fff;color:#ef4444;border:2px solid #fee2e2;box-shadow:0 4px 12px #ef44441a;font-weight:600;transition:all .2s ease}.history-actions .action-button.secondary:hover{background:#fef2f2;border-color:#fecaca;box-shadow:0 6px 16px #ef444426}.history-actions .action-button.secondary:active:not(:disabled){background:#fee2e2;transform:translateY(1px)}@media(max-width:768px){.dashboard-header{padding:16px 16px 20px}.greeting h1{font-size:28px}.greeting p{font-size:14px}.dashboard-content{padding:16px}.balance-amount{font-size:32px}.action-button-large span{font-size:16px}.action-button-icon{width:48px;height:48px}.action-button-icon svg{width:24px;height:24px}.action-grid-small{grid-template-columns:repeat(2,1fr);gap:10px}.action-button-small{padding:20px 12px}.action-button-small svg{width:24px;height:24px}.action-button-small span{font-size:13px}.transaction-row{flex-direction:column;align-items:flex-start;gap:6px}.transaction-row .value{text-align:left}.stats-grid{grid-template-columns:1fr;gap:10px}.stat-card{display:flex;justify-content:space-between;align-items:center;text-align:left;padding:16px}.stat-value{font-size:24px;margin-bottom:0}.stat-label{font-size:14px}.token-item,.history-row{flex-direction:column;align-items:flex-start;gap:6px}.token-item .value,.history-row .value{text-align:left}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{width:100%;min-height:100vh}
