:root{font-family:DM Sans,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;line-height:1.6;font-weight:400;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--color-bg: #fff7ed;--color-surface: #ffffff;--color-surface-elevated: #fafafa;--color-border: #e0e0e0;--color-text: #1a1a1a;--color-text-muted: #5c5c5c;--color-accent: #2563eb;--color-accent-hover: #1d4ed8;--color-accent-muted: rgba(37, 99, 235, .1);--color-error: #b91c1c;--color-success: #15803d;--radius: 8px;--radius-sm: 6px;--shadow: 0 1px 3px rgba(0, 0, 0, .08);--safe-area-inset-top: env(safe-area-inset-top, 0);--safe-area-inset-bottom: env(safe-area-inset-bottom, 0);--safe-area-inset-left: env(safe-area-inset-left, 0);--safe-area-inset-right: env(safe-area-inset-right, 0)}*{box-sizing:border-box;margin:0;padding:0}html{-webkit-tap-highlight-color:transparent;scroll-behavior:smooth}body{min-height:100vh;min-height:100dvh;background-color:var(--color-bg);background-image:radial-gradient(circle at 0% 0%,#facc15 0,transparent 55%),radial-gradient(circle at 100% 0%,#f97316 0,transparent 55%),linear-gradient(180deg,#fff7ed,#fef9c3 40%,#fef3c7);color:var(--color-text);padding-left:var(--safe-area-inset-left);padding-right:var(--safe-area-inset-right)}#root{max-width:1120px;margin:0 auto;padding:2.5rem 1.5rem 3rem;padding-top:calc(2.5rem + var(--safe-area-inset-top));padding-bottom:calc(3rem + var(--safe-area-inset-bottom))}input,select,button{font-family:inherit}@media(max-width:768px){#root{padding:1.25rem 1rem 2rem;padding-top:calc(1.25rem + var(--safe-area-inset-top));padding-bottom:calc(2rem + var(--safe-area-inset-bottom))}}@media(max-width:480px){#root{padding:1rem .75rem 1.5rem;padding-top:calc(1rem + var(--safe-area-inset-top));padding-bottom:calc(1.5rem + var(--safe-area-inset-bottom))}}.app-shell{max-width:1120px;margin:0 auto;padding:1.75rem 1.25rem 2.5rem}.main-content{margin-top:1rem}.app-header{margin-bottom:1.75rem;background:#fffffff5;border-radius:20px;padding:1.25rem 1.75rem;border:1px solid rgba(148,163,184,.4);box-shadow:0 22px 45px #0f172a1f;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.app-header-row{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.75rem}.app-logo{display:flex;align-items:center;gap:12px}.app-logo-text{flex:1 1 auto;min-width:0}.app-user{display:flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:flex-end}.app-username{font-size:.9rem;color:var(--color-text-muted);font-weight:500}.app-user-card,.app-user-credits-card{display:flex;align-items:center;gap:12px;padding:8px 14px;border-radius:999px;background:#fff;border:1px solid rgba(148,163,184,.55);box-shadow:0 6px 18px #0f172a1f,0 0 0 1px #ffffffa6;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.app-user-avatar{width:32px;height:32px;border-radius:999px;background:linear-gradient(135deg,#2563eb,#1d4ed8);color:#fff;font-weight:700;font-size:1rem;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 10px #2563eb73}.app-user-meta{display:flex;flex-direction:column;gap:4px}.app-user-name-row{display:flex;align-items:baseline;gap:4px}.app-user-greeting{font-size:.8rem;color:var(--color-text-muted)}.app-user-name{font-size:.95rem;font-weight:600;color:var(--color-text)}.app-user-secondary-row{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.app-user-role-pill{font-size:.75rem;text-transform:uppercase;letter-spacing:.06em;padding:2px 8px;border-radius:999px;background:#0f172a0f;color:#0f172a;font-weight:600}.app-user-credits-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.1em;color:var(--color-text-muted);font-weight:600;opacity:.9}.app-user-credits-value{font-size:1.5rem;font-weight:700;color:#0f172a;line-height:1.2;letter-spacing:-.02em}@media(max-width:768px){.app-shell{padding-inline:.5rem}.app-header{margin-bottom:1.25rem;padding:1rem 1.25rem}.app-nav-bar{flex-direction:column;align-items:stretch;gap:.75rem}.app-nav-credits{justify-content:flex-end}.app-header-row{flex-direction:column;align-items:flex-start}.app-logo{width:100%;justify-content:space-between}.app-logo-text{flex:1;min-width:180px}.app-title{font-size:1.35rem}.app-subtitle{font-size:.85rem}.app-user{width:100%;justify-content:space-between}.app-user-card{flex:1}.app-user-credits-card{order:3;width:100%;flex-direction:row;justify-content:space-between;min-width:unset}.btn-logout{padding-inline:14px;min-height:44px}.app-nav{padding-inline:.25rem;overflow-x:auto;overflow-y:hidden;justify-content:flex-start;-webkit-overflow-scrolling:touch;scrollbar-width:thin}.app-nav::-webkit-scrollbar{height:4px}.app-nav::-webkit-scrollbar-thumb{background:#94a3b8e6;border-radius:999px}.app-nav-item{min-height:44px;flex-shrink:0}.card{padding:1.5rem 1.25rem}.main-content{margin-top:.75rem}.vars-grid .form-input{min-width:100%}.search-input-wrap{max-width:100%}.reports-filters{padding:1rem}.reports-filters-row{flex-direction:column}.reports-filters-row .form-group{min-width:100%}.reports-apply-wrap .btn{width:100%;min-height:44px}.reports-stats{flex-direction:column}.reports-stat{min-width:100%}.reports-table-wrap,.admin-table-wrap,.admin-table-wrap-users{margin-inline:-1.25rem;border-radius:0;border-left:none;border-right:none}.templates-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;margin-inline:-1.25rem;border-radius:0;border-left:none;border-right:none}.templates-table{min-width:720px;table-layout:auto}.templates-table .col-category,.templates-table .col-status{min-width:72px}.templates-table .col-actions{min-width:200px}.templates-table .col-actions .btn-action{white-space:nowrap}.templates-filters-row{flex-direction:column}.templates-filters-row .form-group,.templates-filters-row .search-input-wrap,.templates-card .form-row .form-select{min-width:100%}.templates-pagination{flex-direction:column;align-items:stretch;gap:.75rem}.templates-pagination-controls{justify-content:center}.card-title-row{flex-direction:column;align-items:flex-start}.card-title-row .btn{width:100%;min-height:44px}.templates-user-rates{flex-direction:column;gap:.5rem}.btn-create-template{width:100%;min-height:44px}.modal-backdrop-admin{padding:1rem .75rem;align-items:flex-start}.modal-dialog-admin{max-height:calc(100dvh - 2rem);margin:auto 0}.modal-header-admin,.modal-body-admin{padding-inline:1.25rem}.form-row{flex-direction:column}.form-row .form-group{min-width:100%}.form-actions{flex-direction:column}.form-actions .btn{width:100%;min-height:44px}.action-buttons{flex-wrap:wrap}.btn-action{min-height:36px;padding:8px 12px}.confirm-modal-backdrop{padding:1rem;align-items:center}.confirm-modal-dialog{max-width:calc(100% - 2rem)}.confirm-modal-actions{flex-direction:column}.confirm-modal-btn{width:100%;min-height:44px}.btn{min-height:44px}.file-input-trigger{min-height:44px;padding:12px 16px}.credit-logs-table-wrap{max-height:60vh;margin-inline:-1rem}.download-link.btn-link{min-height:44px;padding:10px 16px;display:inline-flex}}@media(max-width:480px){.app-logo-img{height:56px}.app-nav-item{font-size:.8rem;padding-inline:.9rem}.card{padding:1.25rem 1rem}.admin-table th,.admin-table td{padding:10px 8px}.reports-table-wrap,.admin-table-wrap,.admin-table-wrap-users{margin-inline:-1rem}.app-shell{padding-inline:0}.app-header{border-radius:0;margin-inline:-1rem}.app-nav{border-radius:12px;margin-inline:0}}.btn-logout{position:relative;overflow:hidden;padding:8px 18px;border-radius:999px;border:1px solid transparent;background-image:linear-gradient(120deg,#2563eb,#1d4ed8);color:#fff;font-size:.85rem;font-weight:600;box-shadow:0 8px 18px #0f172a29}.btn-logout:after{content:"";position:absolute;inset:0;background:radial-gradient(circle at center,rgba(15,23,42,.08),transparent 55%);opacity:0;transform:scale(.4);transition:opacity .25s ease,transform .25s ease}.btn-logout:hover:after{opacity:1;transform:scale(1.05)}.btn-logout:hover{background-image:linear-gradient(120deg,#dc2626,#b91c1c);border-color:#ef4444e6;transform:translateY(-1px);box-shadow:0 10px 24px #0f172a38}.btn-logout:active{transform:translateY(0);box-shadow:0 4px 10px #0f172a42}.btn-logout-label{position:relative;z-index:1}.app-logo-icon{width:48px;height:48px;background:var(--color-accent);border-radius:var(--radius);display:flex;align-items:center;justify-content:center;font-size:1.5rem}.app-logo-img{height:72px;width:auto;object-fit:contain;border-radius:0;background:transparent;box-shadow:none}.app-title{font-size:1.75rem;font-weight:700;letter-spacing:-.02em;color:var(--color-text);line-height:1.2}.app-subtitle{font-size:.95rem;color:var(--color-text-muted);font-weight:500;margin-top:.25rem;white-space:normal;overflow:visible;min-width:0}.app-subtitle-full{width:100%;margin-top:.5rem;margin-bottom:0;padding-top:.5rem;border-top:1px solid rgba(148,163,184,.2)}.card{background:var(--color-surface);border:1px solid rgba(148,163,184,.3);border-radius:16px;padding:2rem 2rem 1.75rem;margin-bottom:1.75rem;box-shadow:0 4px 6px -1px #0000000d,0 2px 4px -2px #00000008;transition:box-shadow .25s cubic-bezier(.4,0,.2,1),border-color .25s ease}.card:hover{border-color:#94a3b873;box-shadow:0 10px 15px -3px #0000000f,0 4px 6px -4px #0000000a}.card-title{font-size:1.2rem;font-weight:600;margin-bottom:1.25rem;display:flex;align-items:center;gap:10px;color:var(--color-text);letter-spacing:-.02em}.card-title-icon{width:40px;height:40px;background:var(--color-accent-muted);border-radius:var(--radius);display:flex;align-items:center;justify-content:center;font-size:1.1rem}.form-group{margin-bottom:1.25rem}.form-label{display:block;font-size:.875rem;font-weight:500;color:var(--color-text-muted);margin-bottom:8px}.form-input,.form-select{width:100%;padding:12px 16px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:10px;color:var(--color-text);font-size:1rem;transition:border-color .2s ease,box-shadow .2s ease}.form-input:focus,.form-select:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 3px #2563eb26}.form-input:focus-visible,.form-select:focus-visible{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 3px #2563eb33}.form-input::placeholder{color:var(--color-text-muted);opacity:.7}.form-select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%235c5c5c' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px}.search-input-wrap{position:relative;display:flex;align-items:center;width:100%;min-width:200px;max-width:320px}.search-input-wrap .search-input-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--color-text-muted);opacity:.7;pointer-events:none;display:flex;align-items:center;justify-content:center;transition:color .2s ease,opacity .2s ease}.search-input-wrap:focus-within .search-input-icon{color:var(--color-accent);opacity:1}.search-input{width:100%;padding:12px 40px 12px 44px;background:#fffffff2;border:1px solid rgba(148,163,184,.35);border-radius:14px;color:var(--color-text);font-size:.95rem;font-family:inherit;transition:all .25s cubic-bezier(.4,0,.2,1);box-shadow:0 1px 3px #0f172a0a,0 0 0 1px #94a3b814}.search-input::placeholder{color:var(--color-text-muted);opacity:.75}.search-input:hover{border-color:#94a3b880;box-shadow:0 2px 6px #0f172a0f,0 0 0 1px #94a3b81f}.search-input:focus{outline:none;border-color:var(--color-accent);background:#fff;box-shadow:0 2px 8px #2563eb1f,0 0 0 3px #2563eb2e}.search-input:focus-visible{outline:none}.search-input-wrap .search-input-clear{position:absolute;right:10px;top:50%;transform:translateY(-50%);width:28px;height:28px;display:flex;align-items:center;justify-content:center;border:none;background:#64748b1f;color:var(--color-text-muted);border-radius:8px;cursor:pointer;transition:all .2s ease}.search-input-wrap .search-input-clear:hover{background:#b91c1c1f;color:var(--color-error)}.search-input-wrap .search-input-clear:active{transform:translateY(-50%) scale(.95)}.search-input-wrap .search-input-clear:focus-visible{outline:none;box-shadow:0 0 0 2px #2563eb66}.search-row{display:flex;align-items:center;flex-wrap:wrap;gap:.75rem}.btn{padding:12px 22px;font-size:.95rem;font-weight:600;border:none;border-radius:12px;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);display:inline-flex;align-items:center;justify-content:center;gap:8px}.btn:focus-visible{outline:none;box-shadow:0 0 0 3px #2563eb59}.btn-primary{background:var(--color-accent);color:#fff;box-shadow:0 2px 4px #2563eb4d;position:relative;overflow:hidden}.btn-primary:after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(255,255,255,.2) 0%,transparent 50%);opacity:0;transition:opacity .2s ease}.btn-primary:hover:not(:disabled){background:var(--color-accent-hover);box-shadow:0 4px 12px #2563eb66;transform:translateY(-1px)}.btn-primary:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 4px #2563eb4d}.btn-primary:hover:not(:disabled):after{opacity:1}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-outlined{background:transparent;color:var(--color-text-muted);border:1.5px solid var(--color-border);box-shadow:none}.btn-outlined:hover{background:#0f172a0a;border-color:var(--color-text-muted);color:var(--color-text)}.btn-secondary{background:var(--color-surface-elevated);color:var(--color-text);border:1px solid var(--color-border)}.btn-secondary:hover:not(:disabled){background:#f0f0f0;border-color:#d0d0d0}.phone-input{display:flex;align-items:stretch;border-radius:var(--radius-sm);overflow:hidden;border:1px solid var(--color-border);background:var(--color-surface)}.phone-prefix{padding:10px 12px;background:var(--color-surface-elevated);color:var(--color-text-muted);font-weight:600;font-size:.95rem;display:flex;align-items:center;border-right:1px solid var(--color-border)}.phone-input .form-input{border:none;border-radius:0;flex:1}.phone-input:focus-within{border-color:var(--color-accent)}.vars-grid{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:1rem}.vars-grid .form-input{flex:1;min-width:140px}.file-input-wrapper{position:relative;display:inline-block}.file-input-wrapper input[type=file]{position:absolute;opacity:0;width:100%;height:100%;cursor:pointer;z-index:1}.file-input-trigger{display:inline-flex;align-items:center;gap:10px;padding:10px 16px;background:var(--color-surface-elevated);border:1px dashed var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-muted);font-size:.95rem;transition:border-color .15s,color .15s;cursor:pointer}.file-input-wrapper:hover .file-input-trigger,.file-input-wrapper:has(input:focus) .file-input-trigger{border-color:var(--color-accent);color:var(--color-accent)}.file-selected{margin-top:10px;font-size:.9rem;color:var(--color-accent);display:flex;align-items:center;gap:6px}.response-box{margin-top:1rem;padding:1rem 1.25rem;background:var(--color-surface-elevated);border-radius:10px;font-family:ui-monospace,monospace;font-size:.85rem;overflow-x:auto;white-space:pre-wrap;word-break:break-all;color:var(--color-text-muted);border:1px solid var(--color-border);line-height:1.5}.status-message{margin-top:1rem;padding:14px 18px;border-radius:10px;font-weight:500;display:flex;align-items:center;gap:10px;line-height:1.5}.status-success{background:#15803d1f;color:var(--color-success)}.status-error{background:#b91c1c1f;color:var(--color-error)}.status-pending{background:#5c5c5c1a;color:var(--color-text-muted)}.info-text{font-size:.875rem;color:var(--color-text-muted);margin-bottom:1rem;line-height:1.65}.info-text b{color:var(--color-text)}.download-link{display:inline-flex;align-items:center;gap:8px;color:var(--color-accent);text-decoration:none;font-weight:500;font-size:.9rem;margin-bottom:1rem;transition:color .2s}.download-link:hover{text-decoration:underline}.app-nav-bar{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1.5rem}.app-nav{display:flex;flex-wrap:wrap;gap:.5rem;padding:.4rem;border-radius:14px;background:#ffffffe6;box-shadow:0 18px 40px #0f172a38;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid rgba(148,163,184,.4)}.app-nav-item{border-radius:10px!important;padding:.5rem 1.15rem;font-size:.88rem;color:var(--color-text-muted);border:none;background:transparent;font-weight:500;letter-spacing:.02em;text-transform:uppercase;position:relative;overflow:hidden;transition:color .18s ease-out,background-image .18s ease-out,box-shadow .18s ease-out,transform .12s ease-out}.app-nav-item:before{content:"";position:absolute;inset:0;background:linear-gradient(120deg,#2563eb17,#38bdf814);opacity:0;transform:scale(.9);transition:opacity .18s ease-out,transform .18s ease-out}.app-nav-item:hover:before{opacity:1;transform:scale(1)}.app-nav-item:hover{color:#0f172a}.app-nav-item-active{color:#fff!important;background-image:linear-gradient(120deg,#2563eb,#1d4ed8,#0ea5e9)!important;box-shadow:0 12px 30px #2563eb99;font-weight:700;transform:translateY(-1px)}.app-nav-item-active:before{opacity:0}.app-nav-credits{display:flex;align-items:center}.card-title-row{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem;margin-bottom:1rem}.card-title-row .card-title{margin-bottom:0}.admin-form{margin-bottom:1.5rem;padding:1rem 0;border-bottom:1px solid var(--color-border)}.form-row{display:flex;flex-wrap:wrap;gap:1rem}.form-row .form-group{flex:1;min-width:140px}.form-actions{display:flex;gap:10px;margin-top:1rem}.template-chips{display:flex;flex-wrap:wrap;gap:8px}.template-chip{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;background:var(--color-surface-elevated);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:.85rem;cursor:pointer}.template-chip input{margin:0}.template-chip:has(input:checked){border-color:var(--color-accent);background:var(--color-accent-muted)}.admin-table-wrap{overflow-x:auto;overflow-y:visible;border-radius:12px;border:1px solid rgba(148,163,184,.15);box-shadow:0 1px 3px #0000000a;background:#fff}.admin-table-wrap-fit{overflow:visible;width:100%;min-width:0}.admin-table-wrap-users{overflow-x:auto;width:100%}.admin-table{width:100%;border-collapse:collapse;font-size:.9rem}.admin-table-users{table-layout:auto;white-space:nowrap}.admin-table-users .col-name{min-width:90px}.admin-table-users .col-username{min-width:100px}.admin-table-users .col-role{min-width:80px}.admin-table-users .col-number{min-width:160px}.admin-table-users .col-credits,.admin-table-users .col-utility{min-width:70px}.admin-table-users .col-marketing{min-width:80px}.admin-table-users .col-actions{min-width:180px}.admin-table-users th,.admin-table-users td{padding:12px 10px;white-space:nowrap}.admin-table-users .col-actions{white-space:nowrap}.admin-table th,.admin-table td{padding:14px 18px;text-align:left;border-bottom:1px solid rgba(148,163,184,.12)}.admin-table tbody tr{transition:background-color .15s ease,box-shadow .2s ease}.admin-table tbody tr:nth-child(2n){background:#f9fafb80}.admin-table tbody tr:hover{background:#f1f5f9e6!important}.admin-table th{font-weight:600;color:var(--color-text-muted);font-size:.7rem;text-transform:uppercase;letter-spacing:.08em;background:#f8fafcf2;border-bottom:1px solid rgba(148,163,184,.2)}.role-badge{display:inline-block;padding:4px 10px;border-radius:6px;font-size:.78rem;font-weight:600;text-transform:capitalize;letter-spacing:.02em}.role-superadmin{background:#2563eb1f;color:var(--color-accent);border:1px solid rgba(37,99,235,.25)}.role-admin{background:#f8fafce6;color:var(--color-text-muted);border:1px solid rgba(148,163,184,.3)}.audit-action{display:inline-block;padding:3px 8px;border-radius:6px;font-size:.75rem;font-weight:600}.audit-action-create{background:#0596691f;color:#059669}.audit-action-update{background:#2563eb1f;color:var(--color-accent)}.audit-action-delete{background:#b91c1c1f;color:var(--color-error)}.audit-logs-table .audit-details{max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-logs-modal{max-width:640px}.user-logs-body{padding-bottom:1.5rem}.user-logs-tabs{display:flex;gap:.5rem;margin-bottom:1rem}.user-logs-tab-btn{padding:8px 16px;font-size:.9rem;font-weight:600;border-radius:8px;border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text-muted);cursor:pointer;transition:all .2s ease}.user-logs-tab-btn:hover{background:var(--color-surface-elevated);color:var(--color-text);border-color:#2563eb59}.user-logs-tab-btn-active{background:#2563eb1f;color:var(--color-accent);border-color:#2563eb59}.user-logs-content .credit-logs-table-wrap,.user-logs-content .audit-logs-table-wrap{max-height:360px;overflow-y:auto}.user-logs-content .admin-table{font-size:.82rem}.user-logs-content .admin-table th,.user-logs-content .admin-table td{padding:6px 8px}.action-buttons{display:flex;flex-wrap:wrap;align-items:center;gap:6px}.action-buttons-inline{flex-wrap:nowrap;white-space:nowrap}.btn-action{padding:5px 10px;font-size:.72rem;font-weight:600;border-radius:8px;border:none;cursor:pointer;transition:all .2s ease;box-shadow:0 1px 2px #0000000f;text-transform:none;letter-spacing:.01em}.admin-table-users .action-buttons{gap:6px}.admin-table-users .btn-action{padding:6px 12px;font-size:.8rem}.btn-action-edit{background:linear-gradient(180deg,#fff,#f8fafc);color:var(--color-accent);border:1px solid rgba(37,99,235,.35)}.btn-action-edit:hover{background:linear-gradient(180deg,#eff6ff,#dbeafe);border-color:#2563eb99;box-shadow:0 2px 6px #2563eb33;transform:translateY(-1px)}.btn-action-credits{background:linear-gradient(180deg,#fff,#f8fafc);color:#059669;border:1px solid rgba(5,150,105,.35)}.btn-action-credits:hover{background:linear-gradient(180deg,#ecfdf5,#d1fae5);border-color:#05966999;box-shadow:0 2px 6px #05966933;transform:translateY(-1px)}.btn-action-logs{background:linear-gradient(180deg,#fff,#f8fafc);color:#6366f1;border:1px solid rgba(99,102,241,.35)}.btn-action-logs:hover{background:linear-gradient(180deg,#eef2ff,#e0e7ff);border-color:#6366f199;box-shadow:0 2px 6px #6366f133;transform:translateY(-1px)}.btn-credit-history{font-size:.75rem;margin-left:.5rem;padding:.15rem .35rem;color:var(--color-accent)}.btn-credit-history:hover{text-decoration:underline}.credit-logs-table-wrap{max-height:400px;overflow-y:auto;overflow-x:auto;-webkit-overflow-scrolling:touch}.credit-logs-table{font-size:.9rem}.credit-logs-table .credit-log-type-add{color:var(--color-success);font-weight:500}.credit-logs-table .credit-log-type-deduct{color:var(--color-error);font-weight:500}.credit-logs-table .credit-amount-add{color:var(--color-success)}.credit-logs-table .credit-amount-deduct{color:var(--color-error)}.credit-logs-table .credit-log-desc{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.btn-action-danger{background:linear-gradient(180deg,#fff,#fef2f2);color:var(--color-error);border:1px solid rgba(239,68,68,.4)}.btn-action-danger:hover{background:linear-gradient(180deg,#fef2f2,#fee2e2);border-color:#ef4444b3;box-shadow:0 2px 6px #ef444440;transform:translateY(-1px)}.btn-link{background:#0f172a05;border:1px solid rgba(148,163,184,.4);padding:4px 10px;border-radius:999px;font-size:.82rem;color:var(--color-accent);cursor:pointer;text-decoration:none;display:inline-flex;align-items:center;gap:4px;transition:background-color .15s ease,border-color .15s ease,transform .1s ease}.btn-link:hover{background:#2563eb14;border-color:#2563eba6;transform:translateY(-.5px)}.btn-link-danger{color:var(--color-error);border-color:#ef444499}.btn-link-danger:hover{background:#ef44441f;border-color:#ef4444e6}.modal-backdrop-admin{position:fixed;inset:0;background:#0f172a73;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:flex;align-items:flex-start;justify-content:center;padding:2rem 1rem;z-index:1050;animation:modal-backdrop-fade-in .18s ease-out;overflow-y:auto}.modal-dialog-admin{width:100%;max-width:640px;background:var(--color-surface);border-radius:16px;box-shadow:0 25px 50px -12px #0003,0 0 0 1px #0000000d;border:1px solid rgba(148,163,184,.3);overflow:hidden;transform-origin:top center;animation:modal-dialog-pop .22s ease-out;max-height:calc(100vh - 4rem);display:flex;flex-direction:column}.modal-header-admin{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;border-bottom:1px solid var(--color-border)}.modal-title-admin{font-size:1.05rem;font-weight:600}.btn-close-admin{border:none;background:transparent;font-size:1.5rem;line-height:1;cursor:pointer;color:var(--color-text-muted);min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center;border-radius:10px;transition:background .2s,color .2s}.btn-close-admin:hover{color:var(--color-text);background:#0f172a0f}.btn-close-admin:focus-visible{outline:none;box-shadow:0 0 0 2px #2563eb59}.modal-body-admin{padding:1.25rem 1.5rem 1.5rem;margin:0;border-bottom:none;overflow-y:auto;flex:1 1 auto}.modal-footer-admin{justify-content:flex-end;padding-top:1rem;border-top:1px solid var(--color-border);margin-top:0}.modal-dialog-confirm .confirm-modal-text{font-size:.95rem;line-height:1.6;color:var(--color-text-muted);margin:0}.templates-loading{display:flex;flex-direction:column;align-items:center;gap:1.25rem;padding:3.5rem 1rem}.templates-loading-spinner{width:40px;height:40px;border:3px solid rgba(37,99,235,.2);border-top-color:var(--color-accent);border-radius:50%;animation:templates-spin .8s linear infinite}@keyframes templates-spin{to{transform:rotate(360deg)}}.templates-card{background:var(--color-surface);box-shadow:0 4px 6px -1px #0000000d,0 2px 4px -2px #00000008,0 0 0 1px #94a3b81f;border-radius:16px;overflow:hidden}.templates-total-count{font-weight:500;color:var(--color-text-muted);font-size:.9em}.templates-user-rates{display:flex;gap:1.5rem;align-items:center;font-size:.9rem;color:var(--color-text-muted)}.templates-user-rates strong{color:var(--color-text)}.btn-create-template{padding:8px 18px;font-size:.875rem;border-radius:12px;box-shadow:0 2px 8px #2563eb40}.templates-content{width:100%;min-width:0}.templates-table-wrap{width:100%;min-width:0;overflow-x:auto;overflow-y:visible;border:1px solid rgba(148,163,184,.15);background:#fff;box-shadow:0 1px 3px #0000000a}.templates-table{table-layout:fixed;width:100%;min-width:900px}.templates-table .col-key{width:15%;min-width:100px}.templates-table .col-name{width:16%;min-width:120px}.templates-table .col-category{width:10%;min-width:90px;white-space:nowrap}.templates-table .col-status{width:10%;min-width:95px;overflow:visible}.templates-table .col-lang{width:6%;min-width:50px}.templates-table .col-vars{width:5%;min-width:45px}.templates-table .col-number{width:18%;min-width:130px}.templates-table .col-number .cell-text{font-variant-numeric:tabular-nums}.templates-table .col-actions{width:20%;min-width:200px}.templates-table:not(:has(.col-number)) .col-key{width:17%}.templates-table:not(:has(.col-number)) .col-name{width:19%}.templates-table:not(:has(.col-number)) .col-category{width:14%}.templates-table:not(:has(.col-number)) .col-status{width:14%;overflow:visible}.templates-table:not(:has(.col-number)) .col-actions{width:25%}.templates-table .cell-text{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%}.templates-table th,.templates-table td{padding:12px 14px;overflow:hidden;border-bottom:1px solid rgba(148,163,184,.12)}.templates-table .col-actions:last-child{padding-right:18px}.templates-table tbody tr:nth-child(2n){background:#f9fafb80}.templates-table tbody tr:hover{background:#f1f5f9e6!important}.templates-table th{white-space:nowrap;font-size:.7rem;letter-spacing:.08em;background:#f8fafcf2;border-bottom:1px solid rgba(148,163,184,.2)}.templates-table td.col-status{overflow:visible}.templates-table .col-actions{overflow:visible;white-space:nowrap;box-sizing:border-box}.templates-table .col-actions .action-buttons-inline{flex-wrap:nowrap;gap:6px;min-width:0}.templates-table .col-actions .btn-action{flex-shrink:0;padding:6px 12px;font-size:.8rem}.status-badge{display:inline-block;padding:4px 10px;border-radius:8px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;white-space:nowrap}.status-approved{background:#15803d38;color:#15803d;border:1px solid rgba(21,128,61,.45)}.status-pending,.status-pending_approval{background:#f59e0b1f;color:#b45309;border:1px solid rgba(245,158,11,.25)}.status-rejected{background:#b91c1c1f;color:var(--color-error);border:1px solid rgba(185,28,28,.25)}.status-badge.status-default,.status-badge:not(.status-approved):not(.status-pending):not(.status-pending_approval):not(.status-rejected){background:#64748b1f;color:#64748b;border:1px solid rgba(100,116,139,.25)}.templates-pagination{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:1rem;margin-top:1.5rem;padding:1rem 0;border-top:1px solid rgba(148,163,184,.2)}.templates-pagination-info{font-size:.875rem;color:var(--color-text-muted);font-weight:500}.templates-pagination-controls{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.templates-pagination .pagination-btn{min-width:40px;min-height:40px;padding:0 10px;border-radius:10px;border:1px solid rgba(148,163,184,.4);background:#fff;color:var(--color-text);font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s ease;display:inline-flex;align-items:center;justify-content:center;box-shadow:0 1px 2px #0000000a}.templates-pagination .pagination-btn:focus-visible{outline:none;box-shadow:0 0 0 2px #2563eb59}.templates-pagination .pagination-btn:hover:not(:disabled){background:#2563eb14;border-color:var(--color-accent);color:var(--color-accent);box-shadow:0 2px 6px #2563eb26}.templates-pagination .pagination-btn-active{background:linear-gradient(135deg,#2563eb,#1d4ed8);border-color:transparent;color:#fff;box-shadow:0 2px 8px #2563eb59}.templates-pagination .pagination-btn-active:hover{background:linear-gradient(135deg,#1d4ed8,#1e40af);color:#fff;box-shadow:0 4px 12px #2563eb66}.templates-pagination .pagination-btn:disabled{opacity:.5;cursor:not-allowed}.templates-filters-row{align-items:flex-end}.templates-filters-row .search-input-wrap{min-width:220px}.templates-card .form-row .form-select{border-radius:10px;border:1px solid rgba(148,163,184,.35);min-width:200px}.templates-card .card-title-row{margin-bottom:1.25rem}.templates-card .card-title{font-size:1.25rem;font-weight:700;letter-spacing:-.02em}.confirm-modal-backdrop{position:fixed;inset:0;background:#0f172a85;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;padding:1.5rem;z-index:1050;animation:modal-backdrop-fade-in .2s ease-out}.confirm-modal-dialog{position:relative;width:100%;max-width:420px;background:#fff;border-radius:20px;box-shadow:0 24px 48px -12px #0000002e,0 12px 24px -8px #0000001a,0 0 0 1px #0000000a;overflow:hidden;animation:confirm-modal-scale-in .25s cubic-bezier(.34,1.56,.64,1)}@keyframes confirm-modal-scale-in{0%{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}.confirm-modal-content{padding:2rem 2rem 1.5rem;text-align:center}.confirm-modal-icon-wrap{width:64px;height:64px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 1.25rem}.confirm-modal-icon-danger{background:linear-gradient(135deg,#ef444424,#dc26261a);color:#dc2626;box-shadow:0 4px 12px #dc262633}.confirm-modal-icon-neutral{background:linear-gradient(135deg,#6366f124,#4f46e51a);color:#4f46e5;box-shadow:0 4px 12px #4f46e533}.confirm-modal-icon-svg{width:28px;height:28px}.confirm-modal-title{font-size:1.25rem;font-weight:600;color:#0f172a;margin:0 0 .75rem;letter-spacing:-.02em}.confirm-modal-message{font-size:.95rem;line-height:1.6;color:#64748b;margin:0}.confirm-modal-actions{display:flex;gap:.75rem;padding:0 2rem 2rem;justify-content:center}.confirm-modal-btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.625rem 1.25rem;font-size:.9375rem;font-weight:500;border-radius:12px;cursor:pointer;transition:all .2s ease;border:none}.confirm-modal-btn-cancel{background:#f1f5f9;color:#475569;border:1px solid #e2e8f0}.confirm-modal-btn-cancel:hover{background:#e2e8f0;color:#334155}.confirm-modal-btn-confirm{min-width:120px}.confirm-modal-btn-danger{background:linear-gradient(180deg,#ef4444,#dc2626);color:#fff;box-shadow:0 2px 8px #dc262659}.confirm-modal-btn-danger:hover:not(:disabled){background:linear-gradient(180deg,#f87171,#ef4444);box-shadow:0 4px 14px #dc262666;transform:translateY(-1px)}.confirm-modal-btn-neutral{background:linear-gradient(180deg,#6366f1,#4f46e5);color:#fff;box-shadow:0 2px 8px #4f46e559}.confirm-modal-btn-neutral:hover:not(:disabled){background:linear-gradient(180deg,#818cf8,#6366f1);box-shadow:0 4px 14px #4f46e566;transform:translateY(-1px)}.confirm-modal-btn-icon{width:18px;height:18px}.confirm-modal-spinner{width:18px;height:18px;border:2px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:confirm-modal-spin .6s linear infinite}@keyframes confirm-modal-spin{to{transform:rotate(360deg)}}.confirm-modal-close{position:absolute;top:1rem;right:1rem;width:36px;height:36px;border:none;background:transparent;border-radius:10px;color:#94a3b8;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s,color .2s}.confirm-modal-close:hover{background:#f1f5f9;color:#64748b}.btn-danger{background:linear-gradient(180deg,#dc2626,#b91c1c);color:#fff;box-shadow:0 2px 4px #dc26264d}.btn-danger:hover:not(:disabled){background:linear-gradient(180deg,#ef4444,#dc2626);box-shadow:0 4px 12px #dc262666;transform:translateY(-1px)}.reports-card{position:relative}.reports-desc{margin-bottom:1.25rem;color:var(--color-text-muted)}.reports-filters{background:#f8fafccc;border:1px solid rgba(148,163,184,.2);border-radius:14px;padding:1.5rem;margin-bottom:1.5rem;overflow:hidden}.reports-filters-row{display:flex;flex-wrap:wrap;gap:1rem;align-items:flex-end}.reports-filters-row .form-group{flex:1;min-width:140px;margin-bottom:0}.reports-apply-wrap{flex:0 0 auto}.reports-search-wrap{min-width:0}.reports-search-wrap .search-input-wrap{min-width:140px;max-width:100%}.reports-loading{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:3rem 1rem}.reports-loading-spinner{width:40px;height:40px;border:3px solid rgba(37,99,235,.2);border-top-color:var(--color-accent);border-radius:50%;animation:reports-spin .8s linear infinite}@keyframes reports-spin{to{transform:rotate(360deg)}}.reports-empty{text-align:center;padding:3rem 1rem}.reports-empty-icon{font-size:3rem;display:block;margin-bottom:.75rem;opacity:.6}.reports-empty-hint{font-size:.85rem;color:var(--color-text-muted);margin-top:.25rem}.reports-stats{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem}.reports-stat{flex:1;min-width:100px;padding:1.25rem 1.5rem;border-radius:14px;background:var(--color-surface);border:1px solid rgba(148,163,184,.25);box-shadow:0 2px 8px #0000000a;display:flex;flex-direction:column;gap:.25rem}.reports-stat-value{font-size:1.5rem;font-weight:700;color:var(--color-text);line-height:1.2}.reports-stat-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-muted);font-weight:600}.reports-stat-total{border-left:4px solid var(--color-accent)}.reports-stat-success{border-left:4px solid var(--color-success)}.reports-stat-pending{border-left:4px solid #f59e0b}.reports-stat-failed{border-left:4px solid var(--color-error)}.reports-table-wrap{border-radius:12px;overflow-x:auto;overflow-y:visible;border:1px solid rgba(148,163,184,.2)}.reports-table th,.reports-table td{padding:14px 16px}.reports-cell-datetime{font-size:.9rem;color:var(--color-text-muted)}.reports-cell-failure{max-width:220px;overflow:visible;text-overflow:ellipsis;font-size:.85rem;color:var(--color-text-muted)}.reports-cell-has-tooltip{position:relative}.reports-cell-has-tooltip:hover:after{content:attr(data-tooltip);position:absolute;left:0;bottom:100%;margin-bottom:6px;padding:8px 12px;background:#1a1a1a;color:#fff;font-size:.8rem;line-height:1.4;white-space:normal;max-width:280px;border-radius:8px;box-shadow:0 4px 12px #0003;z-index:1000;pointer-events:none}.report-status{display:inline-block;padding:4px 10px;border-radius:8px;font-size:.78rem;font-weight:600;text-transform:capitalize}.report-status-success{background:#15803d1f;color:var(--color-success);border:1px solid rgba(21,128,61,.25)}.report-status-info{background:#2563eb1f;color:var(--color-accent);border:1px solid rgba(37,99,235,.25)}.report-status-pending{background:#f59e0b1f;color:#b45309;border:1px solid rgba(245,158,11,.25)}.report-status-error{background:#b91c1c1f;color:var(--color-error);border:1px solid rgba(185,28,28,.25)}.report-status-default{background:#5c5c5c1a;color:var(--color-text-muted);border:1px solid rgba(148,163,184,.3)}.reports-pagination{display:flex;justify-content:center;gap:.5rem;flex-wrap:wrap;margin-top:1.5rem}.reports-page-btn{padding:8px 14px;min-height:40px;min-width:40px;border-radius:8px;border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text);font-weight:500;font-size:.9rem;cursor:pointer;transition:all .2s ease}.reports-page-btn:focus-visible{outline:none;box-shadow:0 0 0 2px #2563eb59}.reports-page-btn:hover{background:#2563eb14;border-color:var(--color-accent);color:var(--color-accent)}.reports-page-btn-active{background:var(--color-accent);border-color:var(--color-accent);color:#fff}.reports-page-btn-active:hover{background:var(--color-accent-hover);border-color:var(--color-accent-hover);color:#fff}@keyframes modal-backdrop-fade-in{0%{opacity:0}to{opacity:1}}@keyframes modal-dialog-pop{0%{opacity:0;transform:translateY(8px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}.login-page{min-height:100vh;min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:2rem;padding-left:max(1rem,env(safe-area-inset-left));padding-right:max(1rem,env(safe-area-inset-right));padding-bottom:max(2rem,env(safe-area-inset-bottom))}.login-card{width:100%;max-width:420px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:20px;padding:2.5rem 2.25rem;box-shadow:0 8px 32px #0000001a,0 0 0 1px #0000000a;transition:box-shadow .25s ease}.login-header{text-align:center;margin-bottom:2rem}.login-logo{width:56px;height:56px;margin:0 auto 1rem;background:#ff8c00;border-radius:var(--radius);display:flex;align-items:center;justify-content:center;font-size:1.75rem}.login-title{font-size:1.5rem;font-weight:700;color:var(--color-text);margin-bottom:.35rem;letter-spacing:-.02em}.login-subtitle{font-size:.9rem;color:var(--color-text-muted);line-height:1.5}.login-logo-img{height:72px;width:auto;margin:0 auto 1.25rem;display:block;border-radius:0;object-fit:contain;background:transparent;box-shadow:none}.login-form{margin-top:.5rem}.btn-login{width:100%;margin-top:.75rem;padding:14px 16px;background:#ff8c00;border-radius:12px;font-weight:600;font-size:1rem}.btn-login:hover:not(:disabled){background:#e67e00}.login-form .form-input{padding:12px 16px;border-radius:10px}.login-error{margin-bottom:1rem;padding:12px 16px;background:#b91c1c1f;color:var(--color-error);border-radius:10px;font-size:.9rem;line-height:1.5}@media(max-width:480px){.login-page{padding:1rem .75rem;align-items:flex-start;padding-top:max(2rem,env(safe-area-inset-top))}.login-card{padding:1.75rem 1.25rem;border-radius:16px}.login-title{font-size:1.35rem}.login-subtitle{font-size:.85rem}.login-logo-img{height:60px}.btn-login,.login-form .form-input{min-height:48px}}
