body{margin:0;min-width:320px;min-height:100vh;background-color:#f5f7fb}:root{font-family:Segoe UI,Inter,-apple-system,BlinkMacSystemFont,Helvetica Neue,Arial,sans-serif;line-height:1.5;font-weight:400;color:#1f2933;background-color:#f5f7fb;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}*,*:before,*:after{box-sizing:border-box}body{margin:0;min-height:100vh;background-color:#f5f7fb;color:#1f2933}#root{min-height:100vh}a{color:inherit}.app{min-height:100vh;display:flex;flex-direction:column;background-color:#f5f7fb}.app--login{background-image:url(/images/background.png);background-position:center center;background-repeat:no-repeat;background-size:cover}.login{position:relative;width:100%;min-height:100vh;display:flex;align-items:center;justify-content:center;padding:clamp(1.5rem,4vw,2.5rem)}.login__overlay{position:absolute;inset:0;background:#06190b59;z-index:0}.login__card{position:relative;z-index:1;width:min(540px,calc(100% - 2rem));display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:clamp(2.75rem,5vw,3.5rem) clamp(2.25rem,6vw,4rem);border-radius:18px;background:#fffffff7;box-shadow:0 32px 56px #10182840;text-align:center}.login__logo{height:50px;width:auto;margin-bottom:.25rem}.login__card h1{margin:0;font-size:clamp(1.6rem,4.6vw,1.85rem);font-weight:500;color:#051c0b}.login__subtitle{margin:0;color:#4b5563;font-size:clamp(.92rem,2.6vw,1.05rem)}.login__input{width:100%;height:clamp(3rem,8vw,3.25rem);border-radius:14px;border:1px solid #d0d5dd;background:#f9fafb;font-size:clamp(1.35rem,4vw,1.6rem);letter-spacing:clamp(.3rem,1.6vw,.6rem);padding:0 1.25rem;text-align:center;color:#0f172a}.login__input:focus{outline:3px solid rgba(5,172,71,.35);border-color:#05ac47;background:#fff}.login__error{margin:.25rem 0 0;font-size:.9rem;color:#b42318;font-weight:500}.dashboard{flex:1;display:flex;flex-direction:column}.dashboard__header{display:flex;justify-content:space-between;align-items:center;gap:1.5rem;padding:1.5rem 2.5rem;background:#fff;box-shadow:0 12px 32px #0f172a14;position:sticky;top:0;z-index:2}.dashboard__brand{display:flex;align-items:center;gap:1.25rem}.dashboard__logo{width:60px;height:60px;object-fit:contain}.dashboard__account{display:flex;flex-direction:column;gap:.15rem}.dashboard__account-label{font-size:.78rem;text-transform:uppercase;letter-spacing:.12em;color:#6b7280}.dashboard__account-name{font-size:1.1rem;font-weight:600;color:#1f2937}.dashboard__logout{display:inline-flex;align-items:center;gap:.55rem;padding:.75rem 1.85rem;border-radius:999px;border:1px solid rgba(5,172,71,.28);background:linear-gradient(135deg,#05ac47 10%,#07974f 90%);color:#fff;font-size:.96rem;font-weight:600;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease;box-shadow:0 18px 30px #05ac4740}.dashboard__logout:hover{transform:translateY(-1px);box-shadow:0 24px 44px #05ac4752}.dashboard__logout:active{transform:translateY(1px);box-shadow:0 10px 20px #05ac4738}.dashboard__logout-icon svg{width:1.15rem;height:1.15rem;stroke:currentColor;fill:none}.dashboard__content{flex:1;display:flex;flex-direction:column;gap:2.25rem;padding:clamp(1.75rem,4vw,2.5rem);padding-top:clamp(2.5rem,6vw,3.5rem)}.card-selection{display:flex;flex-direction:column;gap:1.5rem}.card-selection__header h1{margin:0;font-size:clamp(1.85rem,4.2vw,2rem);font-weight:700;color:#051c0b}.card-selection__description{margin:.35rem 0 0;max-width:540px;font-size:1rem;color:#475467}.card-selection__control{position:relative;display:flex;align-items:center;gap:1rem;width:min(420px,100%);min-height:clamp(3rem,8vw,3.25rem);padding:.85rem 1.2rem;border-radius:18px;border:1px solid rgba(5,172,71,.45);background:linear-gradient(135deg,#05ac47f2,#04853cf2);box-shadow:0 18px 42px #05ac4747;transition:box-shadow .25s ease,transform .25s ease}.card-selection__control:after{content:"";position:absolute;right:1rem;top:50%;transform:translateY(-50%);width:14px;height:8px;background-image:url("data:image/svg+xml,%3Csvg width='14' height='8' viewBox='0 0 14 8' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1.5L7 6.5L13 1.5' stroke='%23ffffff' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-size:14px 8px;pointer-events:none;opacity:.8}.card-selection__control:hover,.card-selection__control:focus-within{transform:translateY(-1px);box-shadow:0 24px 50px #05ac4759}.card-selection__select{flex:1;border:none;background:transparent;font-size:1.08rem;font-weight:600;color:#fff;appearance:none;padding-right:2.75rem;cursor:pointer;letter-spacing:.02em}.card-selection__select:focus{outline:none}.card-selection__select option{color:#051c0b}.card-selection__select option:checked{background:#05ac4726}.card-selection__error{flex:1;padding:0;text-align:center;font-size:1.08rem;font-weight:600;color:#fff;letter-spacing:.02em;margin:0;display:flex;align-items:center;justify-content:center;min-height:1.5rem}.card-selection__error p{margin:0}.loader-overlay{position:fixed;inset:88px 0 0;background:#fffffff2;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:999;display:flex;align-items:center;justify-content:center}@media(max-width:600px){.loader-overlay{top:100px}}.loader-content{display:flex;flex-direction:column;align-items:center;gap:1.5rem;z-index:1}.loader-spinner{width:48px;height:48px;border:4px solid rgba(5,172,71,.2);border-top-color:#05ac47;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loader-text{margin:0;font-size:1.1rem;font-weight:600;color:#051c0b;letter-spacing:.02em}.loader-subtitle{margin:0;font-size:.95rem;font-weight:400;color:#475467;text-align:center;max-width:500px;line-height:1.5}.consumption{border-radius:18px;padding:2rem 2.5rem;box-shadow:0 12px 35px #0f172a14}.consumption__header{display:flex;flex-direction:column;gap:.35rem}.consumption h2{margin:0;font-size:clamp(1.5rem,3.8vw,1.7rem);font-weight:700;color:#051c0b}.consumption__subtitle{margin:.5rem 0 2rem;font-size:1rem;color:#475467}.consumption__subtitle span{font-weight:600;color:#051c0b}.consumption__table-wrapper{width:100%;overflow-x:auto}.consumption__table{width:100%;border-collapse:collapse;min-width:640px}.consumption__table thead{background:#ecfdf3}.consumption__table th{text-align:left;padding:.85rem 1rem;font-size:.85rem;font-weight:700;letter-spacing:.05em;color:#04763e;border-bottom:1px solid rgba(5,172,71,.15)}.consumption__table td{padding:.9rem 1rem;font-size:.95rem;color:#1f2933;border-bottom:1px solid #f1f5f9}.consumption__datetime{display:flex;flex-direction:column;gap:.2rem}.consumption__datetime-date{font-weight:600;color:#051c0b}.consumption__datetime-time{font-size:.82rem;color:#4b5563;letter-spacing:.04em;text-transform:uppercase}.consumption__table tbody tr td:last-child:not([colspan]){color:#05ac47;font-weight:600}.consumption__table tbody tr:nth-child(2n) td{background:#f9fafb}.consumption__table tbody tr:last-child td{border-bottom:none}.consumption__divider{margin:1.75rem -2.5rem 1.25rem;height:1px;width:calc(100% + 5rem);background:linear-gradient(90deg,#05ac4700,#05ac4773,#05ac4700)}.consumption__summary{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:clamp(1rem,4vw,2rem)}.consumption__summary-items{display:flex;flex-wrap:wrap;gap:clamp(.85rem,3vw,1.75rem)}.consumption__summary-item{display:flex;flex-direction:column;min-width:110px;align-items:center;text-align:center}.consumption__summary-value{font-size:.875rem;font-weight:600;color:#051c0b}.consumption__summary-value--currency{color:#05ac47}.consumption__summary-label{margin-top:.35rem;font-size:.875rem;font-weight:500;color:#475467}.consumption__export{display:inline-flex;align-items:center;gap:.45rem;padding:.7rem 1.3rem;border-radius:12px;border:1px solid rgba(5,172,71,.25);background:#05ac471f;color:#04763e;font-size:.92rem;font-weight:600;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease,background .2s ease}.consumption__export:hover{transform:translateY(-1px);background:#05ac472e;box-shadow:0 14px 24px #05ac4726}.consumption__export:active{transform:translateY(1px);box-shadow:0 8px 14px #05ac471f}.consumption__export-icon svg{width:1.1rem;height:1.1rem;stroke:currentColor}.login__button{display:inline-flex;align-items:center;justify-content:center;gap:.65rem;width:100%;margin-top:1.5rem;padding:.9rem 1.75rem;border-radius:999px;border:1px solid rgba(5,172,71,.28);background:linear-gradient(135deg,#05ac47 10%,#07974f 90%);color:#fff;font-size:1.02rem;font-weight:600;cursor:pointer;box-shadow:0 18px 30px #05ac4742;transition:transform .2s ease,box-shadow .2s ease}.login__button:hover{transform:translateY(-1px);box-shadow:0 22px 40px #05ac4752}.login__button:active{transform:translateY(1px);box-shadow:0 12px 18px #05ac4740}.login__button-icon svg{width:1.2rem;height:1.2rem;stroke:currentColor;fill:none}@media(max-width:900px){.dashboard__header{flex-direction:column;align-items:flex-start}.dashboard__logout{align-self:flex-end;margin-left:auto;text-align:center}.consumption{padding:1.75rem}}@media(max-width:768px){.consumption{padding:1.5rem 1.75rem}}@media(max-width:600px){.dashboard__header{flex-direction:row;align-items:center;padding:1.25rem 1.5rem}.dashboard__logout{padding:.65rem 1.5rem;font-size:.9rem;align-self:auto;margin-left:0}.dashboard__content{padding:2.5rem 1.75rem 1.75rem}.card-selection__header h1{font-size:1.6rem}.consumption__table{min-width:unset}}@media(max-width:540px){.login__card{border-radius:16px;gap:.65rem}.login__button{margin-top:1.25rem}}@media(max-width:480px){.dashboard__header{padding:1.25rem}.dashboard__logo{width:50px;height:50px}.dashboard__account-name{font-size:1rem}.dashboard__logout{padding:.6rem 1.25rem;font-size:.85rem}.login{padding:1.25rem}.login__card{width:min(480px,calc(100% - 1rem));padding:2.25rem 1.75rem}.login__subtitle{line-height:1.4}.login__input{padding:0 1rem}.dashboard__content{padding:2.5rem 1.5rem 1.5rem;gap:1.5rem}.consumption{padding:1.5rem}.consumption__table th,.consumption__table td{font-size:.85rem}.consumption__divider{margin:1.5rem -1.5rem 1rem;width:calc(100% + 3rem)}}@media(max-width:400px){.login{padding:1rem}.login__card{padding:2rem 1.25rem;border-radius:14px}.login__button{padding:.75rem 1.25rem}.dashboard__header{padding:1.25rem 1.5rem;gap:1rem}.dashboard__logo{width:48px;height:48px}.dashboard__logout{padding:.55rem 1.15rem;font-size:.8rem}.consumption{padding:1.35rem;border-radius:16px}.dashboard__content{padding-top:2.5rem}.loader-overlay{top:95px}.consumption__divider{margin:1.25rem -1.35rem .9rem;width:calc(100% + 2.7rem)}}
