@import "https://fonts.googleapis.com/css2?family=Inter:opsz,wght@14..32,300;14..32,400;14..32,500;14..32,600;14..32,700&display=swap";@import "https://fonts.googleapis.com/css2?family=Inter:opsz,wght@14..32,300;14..32,400;14..32,500;14..32,600;14..32,700&display=swap";@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--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}}}@layer theme{:root,:host{--font-sans:ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";--font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--color-gray-800:oklch(27.8% .033 256.848);--color-gray-900:oklch(21% .034 264.665);--spacing:.25rem;--text-2xl:1.5rem;--text-2xl--line-height:calc(2 / 1.5);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{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}html,:host{-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;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{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}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,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{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-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{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.m-420{margin:calc(var(--spacing) * 420)}.flex{display:flex}.min-h-\[88vh\]{min-height:88vh}.min-h-screen{min-height:100vh}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.items-center{align-items:center}.justify-center{justify-content:center}.bg-gray-800{background-color:var(--color-gray-800)}.text-2xl{font-size:var(--text-2xl);line-height:var(--tw-leading,var(--text-2xl--line-height))}.text-gray-900{color:var(--color-gray-900)}.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,)}}*{scrollbar-width:none!important;-ms-overflow-style:none!important}::-webkit-scrollbar{width:0!important;height:0!important;display:none!important}body{scrollbar-width:none;-ms-overflow-style:none;overflow-y:auto}body::-webkit-scrollbar{display:none}.home-wrapper,.container,.productos-compacto,.boleta-tabla,.batch-section{scrollbar-width:none;-ms-overflow-style:none}.home-wrapper::-webkit-scrollbar{display:none}.container::-webkit-scrollbar{display:none}.productos-compacto::-webkit-scrollbar{display:none}.boleta-tabla::-webkit-scrollbar{display:none}.batch-section::-webkit-scrollbar{display:none}@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-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}.navbar-minimal{z-index:1000;background:0 0;justify-content:space-between;align-items:center;padding:1rem 2rem;font-family:system-ui,-apple-system,sans-serif;display:flex;position:relative;top:0;left:0;right:0}.logo{align-items:center;gap:12px;text-decoration:none;display:flex}.logo-img{object-fit:contain;width:48px;height:48px}.logo span{color:#1f2937;font-size:32px;font-weight:700}.logo:hover span{background:linear-gradient(135deg,#3b82f6 0%,#1f2937 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;transition:all .3s}.logo:hover .logo-img{transition:transform .3s;transform:scale(1.05)}.menu-wrapper{position:relative}.user-btn,.auth-btn{color:#1f2937;cursor:pointer;background:0 0;border:none;border-radius:40px;align-items:center;gap:.5rem;padding:.5rem .75rem;font-size:1rem;font-weight:500;transition:all .3s;display:flex}.user-btn:hover,.auth-btn:hover{background:#0000000d;transform:translateY(-1px)}.user-avatar{object-fit:cover;border:2px solid #3b82f64d;border-radius:50%;width:47px;height:47px}.arrow{opacity:.6;font-size:1rem;transition:transform .2s}.arrow.up{transform:rotate(180deg)}.dropdown-minimal{z-index:100;background:#fff;border:1px solid #e5e7eb;border-radius:12px;min-width:180px;position:absolute;top:calc(100% + 8px);right:0;overflow:hidden;box-shadow:0 10px 25px #0000001a}.dropdown-option{color:#374151;text-align:left;cursor:pointer;background:0 0;border:none;width:100%;padding:10px 16px;font-family:inherit;font-size:.85rem;text-decoration:none;transition:all .2s;display:block}.dropdown-option:hover{color:#1f2937;background:#f3f4f6}.dropdown-option.logout:hover{color:#ef4444}@media (width<=640px){.navbar-minimal{padding:.75rem 1rem 1.5rem}.logo-img{width:36px;height:36px}.logo span{font-size:22px}.logo{gap:8px}.user-btn span:not(.arrow){display:none}.user-avatar{width:32px;height:32px}.dropdown-minimal{right:-10px}}.home-container{box-sizing:border-box;width:90%;max-width:1800px;margin:0 auto;padding:1rem}.header-logo{flex-wrap:wrap;justify-content:center;align-items:center;gap:1rem;margin-bottom:1.5rem;display:flex}.header-logo img{filter:drop-shadow(0 .125rem .25rem #0000001a);width:4rem;height:auto;transition:transform .2s}.header-logo img:hover{transform:scale(1.05)}.header-logo h1{letter-spacing:-.02em;color:#0000;text-transform:uppercase;white-space:nowrap;background:linear-gradient(135deg,#1a2a3a 0%,#2c3e50 50%,#3498db 100%);-webkit-background-clip:text;background-clip:text;margin:0;font-size:2rem;font-weight:800}@media (width<=40rem){.header-logo{flex-direction:column;gap:.5rem}.header-logo h1{white-space:normal;text-align:center;font-size:1.4rem}.header-logo img{width:3rem}}.three-column-layout{grid-template-columns:1.3fr 1.3fr 2.1fr;align-items:start;gap:1.5rem;margin-bottom:0;display:grid}.contenedor-imagen{box-sizing:border-box;background:#fff;border-radius:1rem;flex-direction:column;gap:1.25rem;width:100%;padding:1.25rem;display:flex;box-shadow:0 .125rem .625rem #00000014}.upload-area{text-align:center;cursor:pointer;box-sizing:border-box;background:#f8f9fa;border:.125rem dashed #3498db;border-radius:1rem;width:100%;padding:2rem 1rem;transition:all .3s}.upload-area:hover,.upload-area.dragging{background:#ecf0f1;border-color:#2980b9}.upload-icon{margin-bottom:.625rem;font-size:3rem}.preview-container{text-align:center;box-sizing:border-box;background:#f8f9fa;border-radius:.75rem;width:100%;padding:1rem}.preview-container h4{color:#2c3e50;margin-bottom:.75rem}.preview-image{object-fit:contain;border-radius:.5rem;width:auto;max-width:100%;height:auto;max-height:18rem}.contenedor-boleta-digital{box-sizing:border-box;background:#fff;border-radius:1rem;flex-direction:column;gap:.75rem;width:100%;padding:1rem;display:flex;box-shadow:0 .125rem .625rem #00000014}.contenedor-boleta-digital h3{color:#2c3e50;margin-bottom:.25rem;font-size:1.1rem}.productos-container{width:100%;margin-bottom:.5rem}.productos-lista{width:100%;max-height:16rem;margin-bottom:.75rem;overflow-y:auto}.producto-item{box-sizing:border-box;background:#f8f9fa;border-left:.125rem solid #3498db;border-radius:.375rem;flex-wrap:wrap;align-items:center;gap:.375rem;width:100%;margin-bottom:.375rem;padding:.375rem;display:flex}.producto-item select,.producto-item input{border:.0625rem solid #ddd;border-radius:.25rem;flex:1;min-width:4rem;padding:.25rem .375rem;font-size:.75rem}.producto-item .monto{color:#27ae60;min-width:4rem;font-size:.75rem;font-weight:700}.btn-eliminar{color:#fff;cursor:pointer;background:#e74c3c;border:none;border-radius:.25rem;padding:.1875rem .5rem;font-size:.7rem;transition:background .2s}.btn-eliminar:hover{background:#c0392b}.form-agregar-manual{box-sizing:border-box;background:#f0f2f5;border-radius:.5rem;flex-flow:row;align-items:center;gap:.9rem;width:100%;padding:.4rem;display:flex}.form-agregar-manual select,.form-agregar-manual input{border:.0625rem solid #ddd;border-radius:.25rem;flex:1;min-width:0;padding:.25rem .4rem;font-size:.7rem}.form-agregar-manual select{max-width:150px}.form-agregar-manual input{max-width:80px}.form-agregar-manual button{color:#fff;cursor:pointer;white-space:nowrap;background:#27ae60;border:none;border-radius:.25rem;padding:.25rem .6rem;font-size:.7rem;transition:background .2s}.form-agregar-manual button:hover{background:#219a52}.btn-guardar-boleta{color:#fff;cursor:pointer;background:#27ae60;border:none;border-radius:.375rem;width:100%;margin-top:.25rem;padding:.5rem;font-size:.85rem;font-weight:700;transition:transform .2s,background .2s}.btn-guardar-boleta:hover{background:#219a52;transform:translateY(-.125rem)}.btn-guardar-boleta:active{transform:translateY(0)}.productos-empty{text-align:center;color:#999;width:100%;padding:1.5rem;font-size:.875rem}.productos-lista::-webkit-scrollbar{width:.375rem}.productos-lista::-webkit-scrollbar-track{background:#f1f1f1;border-radius:.25rem}.productos-lista::-webkit-scrollbar-thumb{background:#3498db;border-radius:.25rem}@media (width<=40rem){.contenedor-boleta-digital{padding:.75rem}.contenedor-boleta-digital h3{font-size:1rem}.form-agregar-manual{flex-direction:column;align-items:stretch}.form-agregar-manual select,.form-agregar-manual input,.form-agregar-manual button{width:100%}.form-agregar-manual button{margin-top:.25rem}.producto-item{gap:.25rem}.producto-item select,.producto-item input{padding:.2rem .25rem;font-size:.7rem}.btn-guardar-boleta{padding:.5rem;font-size:.8rem}}.contenedor-historial{box-sizing:border-box;background:#fff;border-radius:1rem;flex-direction:column;flex:1;gap:1rem;width:100%;min-height:25rem;max-height:calc(100vh - 280px);padding:1.25rem;display:flex;overflow-x:hidden;box-shadow:0 .125rem .625rem #00000014}.contenedor-historial h3{color:#2c3e50;flex-shrink:0;margin-bottom:.5rem}.batch-header{flex-wrap:wrap;flex-shrink:0;justify-content:space-between;align-items:center;gap:.625rem;width:100%;margin-bottom:1rem;display:flex}.total-general{color:#fff;text-align:center;box-sizing:border-box;background:#2c3e50;border-radius:.5rem;flex-shrink:0;width:100%;margin-bottom:1rem;padding:.75rem;font-weight:700}.boletas-list{scroll-behavior:smooth;flex-direction:column;flex:1;gap:1rem;width:100%;padding-right:.25rem;display:flex;overflow:hidden auto}.boletas-list::-webkit-scrollbar{width:.5rem}.boletas-list::-webkit-scrollbar-track{background:#f1f1f1;border-radius:.5rem}.boletas-list::-webkit-scrollbar-thumb{background:#3498db;border-radius:.5rem}.boletas-list::-webkit-scrollbar-thumb:hover{background:#2980b9}.boleta-card{box-sizing:border-box;background:#f8f9fa;border:.0625rem solid #dee2e6;border-radius:.75rem;flex-shrink:0;width:100%;transition:box-shadow .2s;overflow:visible}.boleta-card:hover{box-shadow:0 .25rem .75rem #0000001a}.boleta-header{color:#fff;cursor:pointer;box-sizing:border-box;background:#3498db;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.625rem;width:100%;padding:.75rem 1.125rem;transition:background .2s;display:flex}.boleta-header:hover{background:#2980b9}.foto-badge{background:#ffffff4d;border-radius:1.25rem;margin-left:.5rem;padding:.125rem .5rem;font-size:.6875rem}.btn-eliminar-boleta{cursor:pointer;color:#fff;background:#e74c3c;border:none;border-radius:.375rem;padding:.25rem .75rem;transition:background .2s}.btn-eliminar-boleta:hover{background:#c0392b}.boleta-contenido{box-sizing:border-box;background:#fff;border-top:.0625rem solid #ecf0f1;width:100%;padding:1rem;overflow:visible}.boleta-layout{flex-wrap:wrap;gap:1rem;width:100%;display:flex;overflow:visible}.boleta-foto{flex:1;min-width:8rem;max-width:35%}.boleta-foto img{object-fit:contain;cursor:pointer;border-radius:.5rem;width:auto;max-width:100%;height:auto;max-height:8rem;transition:transform .2s}.boleta-foto img:hover{transform:scale(1.02)}.boleta-tabla{flex:2;width:100%;overflow-x:auto}.productos-tabla{border-collapse:collapse;width:100%;min-width:18rem;font-size:.75rem}.productos-tabla th,.productos-tabla td{text-align:left;border-bottom:.0625rem solid #ecf0f1;padding:.5rem}.productos-tabla th{color:#2c3e50;background:#ecf0f1;font-weight:600}.productos-tabla tr:hover{background:#f8f9fa}.toast-alert{color:#fff;z-index:1000;border-radius:.5rem;padding:.75rem 1.25rem;animation:.3s ease-out slideIn;position:fixed;bottom:1.25rem;right:1.25rem;box-shadow:0 .25rem .5rem #0003}.toast-alert.success{background:#27ae60}.toast-alert.warning{background:#f39c12}.toast-alert.error{background:#e74c3c}@keyframes slideIn{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}.boletas-loading,.boletas-empty,.productos-empty{text-align:center;color:#999;width:100%;padding:2rem}@media (width<=60rem){.three-column-layout{grid-template-columns:1fr;gap:1rem}.header-logo{flex-direction:column;gap:.5rem}.header-logo h1{white-space:normal;text-align:center;font-size:1.4rem}.header-logo img{width:3rem}.producto-item{flex-wrap:wrap}.form-agregar-manual{flex-direction:column}.boleta-header{flex-direction:column;align-items:flex-start}.boleta-layout{flex-direction:column}.boleta-foto{max-width:100%}.boletas-list{max-height:25rem}}@media (width<=40rem){.home-container{width:95%;padding:.5rem}.header-logo h1{font-size:1.2rem}.upload-area{padding:1rem}.upload-icon{font-size:2rem}.batch-actions button{padding:.25rem .5rem;font-size:.7rem}.producto-item select,.producto-item input{font-size:.75rem}.btn-guardar-boleta{padding:.625rem;font-size:.875rem}}.batch-actions{flex-wrap:wrap;gap:.5rem;display:flex}.batch-actions button{cursor:pointer;border:none;border-radius:.375rem;align-items:center;gap:.25rem;padding:.375rem .75rem;font-size:.7rem;font-weight:500;transition:all .2s;display:inline-flex;box-shadow:0 .0625rem .125rem #0000000d}.batch-actions button:hover{transform:translateY(-.125rem);box-shadow:0 .25rem .5rem #0000001a}.batch-actions button:active{box-shadow:none;transform:translateY(0)}.btn-refresh{color:#fff;background:#3498db}.btn-refresh:hover{background:#2980b9}.btn-excel{color:#fff;background:#1e8449}.btn-excel:hover{background:#145c32}.btn-agrupado{color:#fff;background:#27ae60}.btn-agrupado:hover{background:#1e8449}.btn-backup{color:#fff;background:#e67e22}.btn-backup:hover{background:#d35400}.btn-restore{color:#fff;background:#f39c12}.btn-restore:hover{background:#e67e22}.btn-delete-all{color:#fff;background:#e74c3c}.btn-delete-all:hover{background:#c0392b}.tutoriales-contenedor{box-sizing:border-box;background:#fff;border-radius:1rem;width:100%;margin-top:2rem;padding:1.5rem;box-shadow:0 .125rem .625rem #00000014}.tutoriales-contenedor h3{color:#2c3e50;text-align:center;margin-bottom:1.25rem;font-size:1.3rem;font-weight:600}.videos-grid{grid-template-columns:repeat(4,1fr);gap:1.5rem;display:grid}.video-card{cursor:pointer;background:#f8f9fa;border-radius:.75rem;transition:transform .3s,box-shadow .3s;overflow:hidden}.video-card:hover{transform:translateY(-.25rem);box-shadow:0 .5rem 1rem #0000001a}.video-thumbnail{height:0;padding-bottom:56.25%;position:relative;overflow:hidden}.video-thumbnail iframe,.video-thumbnail img{object-fit:cover;border:none;width:100%;height:100%;position:absolute;top:0;left:0}.video-card h4{color:#2c3e50;margin:0;padding:.75rem 1rem .25rem;font-size:.9rem}.video-card p{color:#666;margin:0;padding:0 1rem 1rem;font-size:.75rem}@media (width<=60rem){.videos-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=40rem){.videos-grid{grid-template-columns:1fr}}.tutoriales-contenedor h3{text-align:center;letter-spacing:-.02em;color:#0000;text-transform:uppercase;background:linear-gradient(135deg,#1a2a3a 0%,#2c3e50 50%,#3498db 100%);-webkit-background-clip:text;background-clip:text;margin-bottom:1.5rem;padding-bottom:1rem;font-size:1.8rem;font-weight:800;position:relative}.tutoriales-contenedor h3:after{content:"";content:"";background:#27ae60;border-radius:2px;width:100px;height:3px;position:absolute;bottom:0;left:50%;transform:translate(-50%)}.login-container{background:linear-gradient(135deg,#0f172a 0%,#1e3a5f 100%);justify-content:center;align-items:center;min-height:100vh;padding:1rem;display:flex;position:relative}.login-container:before{content:"";pointer-events:none;background:linear-gradient(#3b82f626 0%,#0000 100%);height:150px;position:absolute;top:0;left:0;right:0}.login-card{z-index:1;background:#fffffffa;border-radius:24px;width:100%;max-width:28rem;padding:2rem;animation:.5s ease-in-out fadeIn;position:relative;box-shadow:0 25px 50px -12px #00000080}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.back-button{color:#64748b;cursor:pointer;background:0 0;border:none;border-radius:.5rem;align-items:center;gap:.5rem;margin-bottom:1.5rem;padding:.5rem 1rem .5rem 0;font-size:.875rem;font-weight:500;transition:all .3s cubic-bezier(.4,0,.2,1);display:inline-flex;position:relative;overflow:hidden}.login-title{text-align:center;background:linear-gradient(135deg,#1e3a5f 0%,#3b82f6 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:.5rem;font-size:1.875rem;font-weight:700}.login-subtitle{color:#64748b;text-align:center;margin-bottom:1.5rem;font-size:.875rem}.form-input{box-sizing:border-box;background:#f8fafc;border:2px solid #e2e8f0;border-radius:12px;width:100%;padding:12px 16px;font-size:.875rem;transition:all .3s}.login-button{color:#fff;cursor:pointer;background:linear-gradient(135deg,#1e3a5f 0%,#3b82f6 100%);border:none;border-radius:40px;width:100%;margin-top:.5rem;padding:12px 24px;font-size:1rem;font-weight:600;transition:all .3s;position:relative;overflow:hidden}.login-button:before{content:"";background:linear-gradient(90deg,#0000,#ffffff4d,#0000);width:100%;height:100%;transition:left .5s;position:absolute;top:0;left:-100%}.login-button:hover:before{left:100%}.login-button:hover{transform:translateY(-2px);box-shadow:0 6px 14px #3b82f666}.login-button:active{transform:translateY(0)}.register-link{text-align:center;color:#64748b;margin-top:1.5rem;font-size:.875rem}.register-link a{color:#3b82f6;font-weight:600;text-decoration:none;transition:all .2s}.register-link a:hover{color:#1e3a5f;text-decoration:underline}@media (width<=640px){.login-card{padding:1.5rem}.login-title{font-size:1.5rem}.form-input{padding:10px 14px}}*{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.register-card{box-sizing:border-box;background:#fffffffa;border-radius:24px;width:100%;max-width:28rem;margin:0 auto;padding:2rem;animation:.5s ease-in-out fadeIn;box-shadow:0 20px 40px #0003}.register-title{text-align:center;background:linear-gradient(135deg,#1e3a5f 0%,#3b82f6 100%);-webkit-text-fill-color:transparent;word-break:keep-all;-webkit-background-clip:text;background-clip:text;margin-bottom:.5rem;font-size:clamp(1.5rem,5vw,1.875rem);font-weight:700}.form-input{box-sizing:border-box;background:#f8fafc;border:2px solid #e2e8f0;border-radius:12px;width:100%;min-width:0;padding:12px 16px;font-size:1rem;transition:all .3s}.form-input:focus{background:#fff;border-color:#3b82f6;outline:none;box-shadow:0 0 0 3px #3b82f61a}.error-message{color:#991b1b;background:linear-gradient(135deg,#fef2f2 0%,#fee2e2 100%);border-left:4px solid #ef4444;border-radius:12px;margin-bottom:1rem;padding:.75rem;font-size:.875rem}.success-message{color:#065f46;background:linear-gradient(135deg,#ecfdf5 0%,#d1fae5 100%);border-left:4px solid #10b981;border-radius:12px;margin-bottom:1rem;padding:.75rem;font-size:.875rem}.register-button{color:#fff;cursor:pointer;background:linear-gradient(135deg,#1e3a5f 0%,#3b82f6 100%);border:none;border-radius:40px;width:100%;margin-top:.5rem;padding:12px 24px;font-size:1rem;font-weight:500;transition:all .3s}.register-button:hover{transform:translateY(-1px);box-shadow:0 6px 14px #3b82f666}@media (width<=640px){.register-card{margin:0 1rem;padding:1.5rem}.register-title{font-size:1.5rem}.form-input{padding:10px 14px;font-size:1rem}}@media (width<=768px){input,select,textarea,button{font-size:16px}}.register-container{background:linear-gradient(135deg,#1a2a4e 0%,#0a0a0a 100%);justify-content:center;align-items:center;width:100%;min-height:100vh;padding:1rem;display:flex;position:relative;overflow-x:hidden}.register-container:before{content:"";pointer-events:none;background:linear-gradient(#3b82f626 0%,#0000 100%);height:150px;position:absolute;top:0;left:0;right:0}.register-card{box-sizing:border-box;z-index:1;background:#fff;border-radius:1rem;width:100%;max-width:28rem;margin:0 auto;padding:2rem;animation:.5s ease-in-out fadeIn;position:relative;box-shadow:0 25px 50px -12px #00000080}.back-button{color:#6b7280;cursor:pointer;white-space:nowrap;background:0 0;border:none;border-radius:.5rem;align-items:center;gap:.5rem;margin-bottom:1.5rem;padding:.5rem 1rem .5rem 0;font-size:.875rem;font-weight:500;transition:all .3s cubic-bezier(.4,0,.2,1);display:inline-flex;position:relative;overflow:hidden}.back-button:before{content:"";z-index:-1;background:linear-gradient(90deg,#1e3a8a1a,#0000);border-radius:.5rem;width:0%;height:100%;transition:width .3s;position:absolute;top:0;left:0}.back-button:hover{color:#1e3a8a;gap:.75rem;transform:translate(-2px)}.back-button:hover:before{width:100%}.back-button:active{transition:transform .1s;transform:translate(0)}.register-title{text-align:center;background:linear-gradient(135deg,#1e3a8a 0%,#000 100%);color:#0000;word-break:keep-all;-webkit-background-clip:text;background-clip:text;margin-bottom:.5rem;font-size:clamp(1.5rem,5vw,1.875rem);font-weight:700}.register-subtitle{color:#6b7280;text-align:center;margin-bottom:1.5rem;font-size:clamp(.75rem,4vw,.875rem)}.form-group{margin-bottom:1rem}.form-label{color:#374151;margin-bottom:.5rem;font-size:.875rem;font-weight:500;display:block}.form-input{box-sizing:border-box;background-color:#f8fafc;border:1px solid #e2e8f0;border-radius:.5rem;width:100%;min-width:0;padding:.625rem .875rem;font-size:1rem;transition:all .2s}.form-input:focus{background-color:#fff;border-color:#1e3a8a;outline:none;box-shadow:0 0 0 3px #1e3a8a1a}.error-message{color:#dc2626;background-color:#fee2e2;border:1px solid #fecaca;border-radius:.5rem;margin-bottom:1rem;padding:.75rem;font-size:.875rem}.register-button{color:#fff;cursor:pointer;background:linear-gradient(135deg,#1e3a8a 0%,#000 100%);border:none;border-radius:.5rem;width:100%;margin-top:.5rem;padding:.75rem .625rem;font-size:1rem;font-weight:500;transition:all .2s;position:relative;overflow:hidden}.register-button:before{content:"";background:linear-gradient(90deg,#0000,#ffffff4d,#0000);width:100%;height:100%;transition:left .5s;position:absolute;top:0;left:-100%}.register-button:hover:before{left:100%}.register-button:hover{background:linear-gradient(135deg,#2563eb 0%,#1a1a1a 100%);transform:translateY(-2px);box-shadow:0 4px 12px #0000004d}.register-button:active{transform:translateY(0)}.login-link{text-align:center;color:#6b7280;margin-top:1.5rem;font-size:.875rem}.login-link a{color:#1e3a8a;font-weight:600;text-decoration:none;transition:all .2s;display:inline-block}.login-link a:hover{color:#2563eb;text-decoration:underline;transform:translate(2px)}@media (width<=640px){.register-card{margin:0 1rem;padding:1.5rem}.register-title{font-size:1.5rem}.form-input{font-size:1rem}}@media (width<=768px){input,select,textarea,button{font-size:16px}}.footer{color:#fff;background:linear-gradient(135deg,#0f2e3a 0%,#1a4a6e 100%);width:100%;margin-top:auto}.footer-container{flex-wrap:wrap;justify-content:space-between;gap:20px;max-width:1200px;margin:0 auto;padding:30px 20px 20px;display:flex}.footer-col-logo{flex:none;justify-content:center;align-items:center;min-width:290px;display:flex}.logo-img{object-fit:contain;filter:drop-shadow(0 4px 8px #0003);width:250px;height:250px;transition:transform .3s}.logo-img:hover{transform:scale(1.05)}@media (width<=900px){.footer-col-logo{min-width:200px}.logo-img{width:140px;height:140px}}@media (width<=480px){.footer-col-logo{min-width:auto}.logo-img{width:100px;height:100px}}.footer-col-bio{flex:2;min-width:200px}.footer-col-bio h3{background:linear-gradient(135deg,#fff 0%,#7ab8d4 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:8px;font-size:20px;font-weight:700}.footer-description{color:#c8dce8;margin-bottom:10px;font-size:13px;line-height:1.5}.footer-contact p{color:#c8dce8;align-items:center;gap:8px;margin:5px 0;font-size:12px;transition:all .3s;display:flex}.footer-col{flex:1;min-width:150px}.footer-col h4{color:#7ab8d4;margin-bottom:15px;padding-bottom:8px;font-size:16px;font-weight:600;position:relative}.footer-col h4:after{content:"";background:linear-gradient(90deg,#2e7db2,#7ab8d4);border-radius:2px;width:35px;height:2px;position:absolute;bottom:0;left:0}.footer-links li{margin-bottom:8px}.footer-links a{color:#c8dce8;font-size:13px;text-decoration:none;transition:all .3s;display:inline-block}.footer-links a:hover{color:#7ab8d4;transform:translate(5px)}.social-links{flex-direction:column;gap:8px;margin-bottom:15px;display:flex}.social-link{color:#c8dce8;align-items:center;gap:8px;font-size:13px;text-decoration:none;transition:all .3s;display:flex}.social-link:hover{color:#7ab8d4;transform:translate(5px)}.social-icon{width:28px;font-size:18px;display:inline-block}.footer-email{border-top:1px solid #7ab8d44d;margin-top:15px;padding-top:10px}.footer-email p{color:#c8dce8;align-items:center;gap:8px;font-size:12px;transition:all .3s;display:flex}.footer-email p:hover{color:#7ab8d4}.footer-bottom{text-align:center;color:#a8c8d8;border-top:1px solid #7ab8d433;padding:15px;font-size:13px}.footer-bottom p{text-align:center;width:100%;margin:0}@media (width<=900px){.footer-container{text-align:center;flex-direction:column;gap:25px;padding:25px 20px 15px}.footer-col-logo{justify-content:center}.footer-col-bio{text-align:center}.footer-contact p{justify-content:center}.footer-col{text-align:center}.footer-col h4:after{left:50%;transform:translate(-50%)}.social-links{align-items:center}.social-link:hover,.footer-links a:hover{transform:translate(0)}}@media (width<=480px){.footer-container{padding:20px 15px 15px}.logo-img{width:80px;height:80px}.footer-col-bio h3{font-size:18px}.footer-description{font-size:12px}.footer-contact p{font-size:11px}.footer-bottom{padding:12px;font-size:11px}}.perfil-container{box-sizing:border-box;background:linear-gradient(135deg,#0f172a 0%,#1e3a5f 100%);justify-content:center;align-items:center;min-height:100vh;margin:0;padding:40px;display:flex}.perfil-card{background:#fffffffa;border-radius:24px;width:100%;max-width:900px;margin:0;padding:40px;transition:transform .3s,box-shadow .3s;animation:.5s ease-out fadeInUp;box-shadow:0 20px 40px #0003}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.perfil-card:hover{transform:translateY(-2px);box-shadow:0 24px 48px #00000040}.card-header{text-align:center;border-bottom:1px solid #e2e8f0;margin-bottom:16px;padding-bottom:12px}.card-header h2{background:linear-gradient(135deg,#1e3a5f 0%,#3b82f6 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:18px;font-size:24px}.card-header h2,.card-header p{font-family:Inter,sans-serif}.card-header p{color:#64748b;font-size:15px}.message{text-align:center;border-radius:12px;margin-bottom:24px;padding:12px 20px;animation:.3s fadeIn}.message.success{color:#155724;background:#d4edda;border-left:4px solid #10b981}.message.error{color:#721c24;background:#f8d7da;border-left:4px solid #ef4444}.perfil-content-horizontal{align-items:center;gap:40px;display:flex}.avatar-section-horizontal{text-align:center;flex:none}.avatar-wrapper-horizontal{display:inline-block;position:relative}.profile-avatar-horizontal{object-fit:cover;background:linear-gradient(135deg,#1e3a5f 0%,#3b82f6 100%);border:4px solid #3b82f6;border-radius:50%;width:280px;height:280px;transition:all .3s;box-shadow:0 8px 20px #00000026}.profile-avatar-horizontal:hover{transform:scale(1.02);box-shadow:0 12px 28px #3b82f64d}.avatar-overlay-horizontal{color:#fff;cursor:pointer;opacity:0;background:linear-gradient(135deg,#1e3a5f 0%,#3b82f6 100%);border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;font-size:18px;transition:all .3s;display:flex;position:absolute;bottom:10px;right:10px}.avatar-wrapper-horizontal:hover .avatar-overlay-horizontal{opacity:1}.info-section-horizontal{flex-direction:column;flex:1;gap:16px;display:flex}.info-group-horizontal{border-bottom:none;padding:8px 0}.info-group-horizontal label{color:#3b82f6;text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px;font-size:12px;font-weight:600;display:block}.info-group-horizontal p{color:#1e293b;margin:0;font-size:18px;font-weight:500}.btn-edit-horizontal{color:#fff;cursor:pointer;background:linear-gradient(135deg,#1e3a5f 0%,#3b82f6 100%);border:none;border-radius:40px;width:100%;margin-top:8px;padding:12px 24px;font-size:16px;font-weight:500;transition:all .3s}.btn-edit-horizontal:hover{transform:translateY(-1px);box-shadow:0 6px 14px #3b82f666}.perfil-form-horizontal{gap:40px;display:flex}.form-section-horizontal{flex-direction:column;flex:1;gap:20px;display:flex}.form-group-horizontal{flex-direction:column;gap:8px;display:flex}.form-group-horizontal label{color:#334155;font-size:14px;font-weight:600}.form-group-horizontal input{background:#f8fafc;border:2px solid #e2e8f0;border-radius:12px;padding:12px 16px;font-size:16px;transition:all .3s}.form-group-horizontal input:focus{background:#fff;border-color:#3b82f6;outline:none;box-shadow:0 0 0 3px #3b82f61a}.form-group-horizontal input:disabled{cursor:not-allowed;color:#94a3b8;background:#f1f5f9}.form-group-horizontal small{color:#94a3b8;font-size:12px}.upload-label-horizontal{cursor:pointer;text-align:center;color:#475569;background:#f1f5f9;border-radius:40px;margin-top:12px;padding:8px 16px;font-size:14px;transition:all .3s;display:block}.upload-label-horizontal:hover{background:#e2e8f0}.form-actions-horizontal{gap:12px;margin-top:8px;display:flex}.btn-save-horizontal{color:#fff;cursor:pointer;background:linear-gradient(135deg,#10b981 0%,#059669 100%);border:none;border-radius:40px;flex:1;padding:12px 24px;font-size:14px;font-weight:600;transition:all .3s}.btn-save-horizontal:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 14px #10b9814d}.btn-cancel-horizontal{color:#fff;cursor:pointer;background:#ef4444;border:none;border-radius:40px;flex:1;padding:12px 24px;font-size:14px;font-weight:600;transition:all .3s}.btn-cancel-horizontal:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 14px #ef44444d}button:disabled{opacity:.6;cursor:not-allowed}.lock-icon{text-align:center;margin-bottom:16px;font-size:48px}.btn-primary{color:#fff;cursor:pointer;background:linear-gradient(135deg,#1e3a5f 0%,#3b82f6 100%);border:none;border-radius:40px;width:100%;padding:12px 24px;font-size:16px;font-weight:500}@media (width<=768px){.perfil-container{padding:20px}.perfil-card{padding:24px}.perfil-content-horizontal,.perfil-form-horizontal{flex-direction:column;gap:24px}.profile-avatar-horizontal{width:150px;height:150px}.info-group-horizontal p{font-size:16px}.card-header h2{font-size:24px}}body,html{margin:0;padding:0;overflow-x:hidden}#root{min-height:100vh;margin:0;padding:0}
