.partner-detail{width:100%;max-width:100%;overflow-x:hidden}.back-btn{background:transparent;color:var(--secondary);padding:0;margin-bottom:var(--spacing-lg);font-weight:500;border:none}.back-btn:hover{color:var(--secondary-light)}.detail-header{background:#fff;border-radius:.5rem;padding:var(--spacing-xl);margin-bottom:var(--spacing-xl);box-shadow:0 1px 3px #0000000d}.detail-header h2{margin-bottom:var(--spacing-lg)}.budget-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:var(--spacing-lg)}.budget-item{display:flex;flex-direction:column;padding:var(--spacing-md);background:var(--neutral-bg);border-radius:.375rem}.budget-item.highlight{background:#3b82f60d;border:2px solid rgba(59,130,246,.2)}.budget-label{font-size:.75rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:var(--spacing-xs)}.budget-value{font-size:1.5rem;font-weight:700;color:var(--primary)}.budget-value.accent{color:var(--secondary)}.budget-value.positive{color:var(--success)}.budget-value.negative{color:var(--error)}.detail-sections{display:grid;grid-template-columns:1fr;gap:var(--spacing-xl)}@media (min-width: 1200px){.detail-sections{grid-template-columns:repeat(2,1fr)}}.detail-section{background:#fff;border-radius:.5rem;padding:var(--spacing-xl);box-shadow:0 1px 3px #0000000d;min-width:0;overflow:hidden}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-lg)}.section-header h3{margin:0}.form{background:var(--neutral-bg);padding:var(--spacing-lg);border-radius:.375rem;margin-bottom:var(--spacing-lg);display:grid;gap:var(--spacing-md)}.error-message{padding:var(--spacing-md);background:#ef44441a;border:1px solid var(--error);border-radius:.375rem;color:var(--error);font-size:.875rem;font-weight:500}.warning-message{padding:var(--spacing-md);background:#f59e0b1a;border:1px solid var(--warning);border-radius:.375rem;color:var(--warning);font-size:.875rem;font-weight:500;margin-bottom:var(--spacing-lg)}.form-group{display:flex;flex-direction:column}.form-group label{font-weight:500;margin-bottom:var(--spacing-xs);color:var(--text-primary)}.form-group input,.form-group select,.form-group textarea{padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--neutral-border);border-radius:.375rem;font-size:.875rem}.form-group textarea{resize:vertical;min-height:80px}.btn{padding:var(--spacing-sm) var(--spacing-lg);border-radius:.375rem;font-weight:500;transition:all .2s ease;border:none;cursor:pointer}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--secondary);color:#fff}.btn-primary:hover{background:var(--secondary-light)}.btn-success{background:var(--success);color:#fff;width:100%}.btn-success:hover{background:#059669}.transactions-list{overflow-x:auto;-webkit-overflow-scrolling:touch}.transactions-list table{min-width:100%;width:max-content}.transactions-list table td.positive{color:var(--success);font-weight:600}.transactions-list table td.negative{color:var(--error);font-weight:600}.empty-message{text-align:center;color:var(--text-secondary);padding:var(--spacing-lg);background:var(--neutral-bg);border-radius:.375rem}.status-label{display:inline-block;padding:var(--spacing-xs) var(--spacing-sm);border-radius:.25rem;font-size:.75rem;font-weight:600}.status-pending{background:#f59e0b1a;color:var(--warning)}.status-approved{background:#3b82f61a;color:var(--secondary)}.status-paid{background:#10b9811a;color:var(--success)}.status-select{padding:var(--spacing-xs) var(--spacing-sm);border:1px solid var(--neutral-border);border-radius:.25rem;font-size:.75rem}.transactions-list table tr.expired{opacity:.6;background:#00000005}.expired-label{font-size:.7rem;color:var(--error);font-weight:600}@media (max-width: 1024px){.detail-sections{grid-template-columns:1fr}}@media (max-width: 768px){.detail-header{padding:var(--spacing-lg)}.budget-summary{grid-template-columns:1fr}.detail-section{padding:var(--spacing-md)}.section-header{flex-direction:column;align-items:flex-start;gap:var(--spacing-md)}.section-header h3{width:100%}.form{padding:var(--spacing-md)}}@media (max-width: 480px){.budget-value{font-size:1.25rem}.budget-item{padding:var(--spacing-sm)}}.yearly-overview h2{margin-bottom:var(--spacing-lg);color:var(--primary)}.yearly-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:var(--spacing-md);margin-bottom:var(--spacing-xl)}.summary-item{display:flex;flex-direction:column;padding:var(--spacing-lg);background:linear-gradient(135deg,var(--secondary) 0%,var(--secondary-light) 100%);border-radius:.5rem;color:#fff;min-width:0;overflow:hidden}.summary-item.highlight{background:linear-gradient(135deg,#0ea5e9,#38bdf8);border:2px solid #0284c7;box-shadow:0 4px 6px #0ea5e933}.summary-item.accent{background:linear-gradient(135deg,var(--primary) 0%,#334155 100%)}.summary-label{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;opacity:.9;margin-bottom:var(--spacing-xs)}.summary-value{font-size:1.5rem;font-weight:700;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.summary-value.positive{color:#d1fae5}.summary-value.negative{color:#fecaca}.yearly-table{overflow-x:auto;-webkit-overflow-scrolling:touch}.yearly-table table{min-width:100%}.yearly-table table{width:100%;border-collapse:collapse}.yearly-table th{background:var(--neutral-bg);padding:var(--spacing-md);text-align:left;font-weight:600;font-size:.875rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid var(--neutral-border)}.yearly-table td{padding:var(--spacing-lg) var(--spacing-md);border-bottom:1px solid var(--neutral-border);font-size:.95rem}.yearly-table tbody tr:hover{background-color:var(--neutral-bg)}.year-cell{font-weight:600;color:var(--secondary);font-size:1.125rem}.percentage-bar{position:relative;height:24px;background:var(--neutral-bg);border-radius:.25rem;overflow:hidden;display:flex;align-items:center}.percentage-fill{position:absolute;height:100%;background:linear-gradient(90deg,var(--secondary),var(--secondary-light));top:0;left:0;transition:width .3s ease}.percentage-text{position:relative;z-index:1;margin-left:var(--spacing-sm);font-weight:600;font-size:.75rem;color:var(--text-primary)}.center{text-align:center;font-weight:600;color:var(--secondary)}@media (max-width: 768px){.yearly-summary{grid-template-columns:1fr}.yearly-table{font-size:.8rem}.yearly-table th,.yearly-table td{padding:var(--spacing-sm)}.summary-value{font-size:1.25rem}}@media (max-width: 480px){.summary-item{padding:var(--spacing-md)}.summary-value{font-size:1.125rem}.yearly-table th,.yearly-table td{padding:var(--spacing-xs);font-size:.75rem}}.dashboard{width:100%;max-width:100%;overflow-x:hidden}.dashboard-grid{display:grid;grid-template-columns:1fr;gap:var(--spacing-xl)}.dashboard-section{background:#fff;border-radius:.5rem;padding:var(--spacing-xl);box-shadow:0 1px 3px #0000000d;min-width:0;overflow:hidden}.dashboard-section h2{margin-bottom:var(--spacing-lg);color:var(--primary)}.partners-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--spacing-xl)}.partner-card{background:#fff;border:1px solid var(--neutral-border);border-radius:.5rem;padding:var(--spacing-lg);cursor:pointer;transition:all .2s ease;min-width:0;overflow:hidden}.partner-card:hover{border-color:var(--secondary);box-shadow:0 4px 6px #0000001a;transform:translateY(-2px)}.partner-card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--spacing-md);margin-bottom:var(--spacing-md)}.partner-card h3{margin:0;font-size:1rem;line-height:1.3;flex:1;overflow:hidden;text-overflow:ellipsis;word-wrap:break-word}.status-badge{font-size:.75rem;font-weight:600;padding:var(--spacing-xs) var(--spacing-sm);border-radius:.25rem;white-space:nowrap}.status-badge.low{background-color:#10b9811a;color:var(--success)}.status-badge.medium{background-color:#3b82f61a;color:var(--secondary)}.status-badge.warning{background-color:#f59e0b1a;color:var(--warning)}.status-badge.critical{background-color:#ef44441a;color:var(--error)}.progress-bar{width:100%;height:6px;background-color:var(--neutral-bg);border-radius:3px;overflow:hidden;margin-bottom:var(--spacing-lg)}.progress-fill{height:100%;background:linear-gradient(90deg,var(--secondary),var(--secondary-light));transition:width .3s ease}.partner-stats{display:grid;grid-template-columns:1fr 1fr 1fr;gap:var(--spacing-md)}.stat{display:flex;flex-direction:column;min-width:0}.stat.highlight{padding:var(--spacing-sm);background:#3b82f60d;border-radius:.375rem;border:1px solid rgba(59,130,246,.2);min-width:70px}.stat-label{font-size:.65rem;font-weight:500;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.3px;margin-bottom:4px;line-height:1.2}.stat-value{font-size:.8rem;font-weight:600;color:var(--text-primary);line-height:1.3;word-break:break-word}.stat-value.positive{color:var(--success)}.stat-value.negative{color:var(--error)}@media (max-width: 768px){.partners-grid{grid-template-columns:1fr}.dashboard-section{padding:var(--spacing-md)}.partner-stats{grid-template-columns:1fr}}@media (max-width: 480px){.partner-card{padding:var(--spacing-md)}.stat-label{font-size:.6rem}.stat-value{font-size:.75rem}}.partner-list{width:100%}.list-header{display:flex;justify-content:space-between;align-items:center;gap:var(--spacing-lg);margin-bottom:var(--spacing-xl);flex-wrap:wrap}.list-header h2{margin:0}.filter-section{display:flex;gap:var(--spacing-md);align-items:center}.filter-section label{font-weight:500;color:var(--text-primary)}.filter-section select{padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--neutral-border);border-radius:.375rem}.partners-table{background:#fff;border-radius:.5rem;overflow:hidden;box-shadow:0 1px 3px #0000000d;overflow-x:auto}.partners-table table{width:100%;border-collapse:collapse}.partners-table th{background:var(--neutral-bg);padding:var(--spacing-sm) var(--spacing-sm);text-align:left;font-weight:600;font-size:.75rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid var(--neutral-border);white-space:nowrap}.partners-table td{padding:var(--spacing-sm) var(--spacing-sm);border-bottom:1px solid var(--neutral-border);font-size:.85rem}.partners-table tbody tr:hover{background-color:var(--neutral-bg)}.partner-name{font-weight:500;color:var(--primary);min-width:180px}.amount{text-align:right;font-variant-numeric:tabular-nums}.amount-badge{display:inline-block;padding:var(--spacing-xs) var(--spacing-sm);border-radius:.25rem;font-size:.75rem;font-weight:600}.amount-badge.advance{background:#3b82f61a;color:var(--secondary)}.amount.positive{color:var(--success)}.amount.negative{color:var(--error)}.percentage-cell{display:flex;gap:var(--spacing-md);align-items:center}.small-progress{width:60px;height:8px;background:var(--neutral-bg);border-radius:4px;overflow:hidden}.small-progress-fill{height:100%;background:linear-gradient(90deg,var(--secondary),var(--secondary-light))}.yearly-breakdown{display:grid;grid-template-columns:repeat(4,1fr);gap:4px;min-width:160px}.year-cell{display:flex;flex-direction:column;align-items:center;padding:4px 2px;background:var(--neutral-bg);border-radius:.25rem;font-size:.65rem}.year-cell .year{font-weight:600;color:var(--text-secondary);margin-bottom:1px}.year-cell .value{font-weight:600;color:var(--primary);font-size:.7rem}.list-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--spacing-lg);margin-top:var(--spacing-xl)}.summary-stat{background:#fff;border-radius:.5rem;padding:var(--spacing-lg);box-shadow:0 1px 3px #0000000d;display:flex;flex-direction:column}.stat-label{font-size:.75rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:var(--spacing-sm)}.stat-value{font-size:1.5rem;font-weight:700;color:var(--secondary)}@media (max-width: 1200px){.yearly-breakdown{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.list-header{flex-direction:column;align-items:stretch}.filter-section{flex-wrap:wrap}.partners-table{font-size:.8rem}.partners-table th,.partners-table td{padding:var(--spacing-sm)}.partner-name{min-width:auto}.yearly-breakdown{grid-template-columns:repeat(2,1fr);min-width:auto}.list-summary{grid-template-columns:1fr}}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.login-box{background:#fff;border-radius:12px;box-shadow:0 10px 40px #0003;padding:48px 40px;width:100%;max-width:420px}.login-box h1{margin:0 0 8px;font-size:28px;font-weight:700;color:#1a1a1a;text-align:center}.login-subtitle{margin:0 0 32px;font-size:14px;color:#666;text-align:center}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;font-size:14px;font-weight:600;color:#333}.form-group input{width:100%;padding:12px 16px;border:1px solid #ddd;border-radius:8px;font-size:15px;transition:all .3s ease;box-sizing:border-box}.form-group input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-group input:disabled{background-color:#f5f5f5;cursor:not-allowed}.error-message{background-color:#fee;color:#c33;padding:12px 16px;border-radius:8px;font-size:14px;margin-bottom:20px;border:1px solid #fcc}.login-button{width:100%;padding:14px 24px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease}.login-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}.login-button:active:not(:disabled){transform:translateY(0)}.login-button:disabled{opacity:.6;cursor:not-allowed}.test-accounts{margin-top:32px;padding-top:32px;border-top:1px solid #e5e5e5}.test-accounts h3{margin:0 0 16px;font-size:14px;font-weight:600;color:#666;text-transform:uppercase;letter-spacing:.5px}.account-info{background-color:#f8f9fa;padding:16px;border-radius:8px;margin-bottom:12px;font-size:13px;line-height:1.6}.account-info:last-child{margin-bottom:0}.account-info strong{display:block;margin-bottom:8px;color:#333;font-size:14px}.account-info div{color:#555;font-family:Courier New,monospace}.app{display:flex;flex-direction:column;min-height:100vh;background-color:var(--neutral-bg)}.header{background:#fff;border-bottom:1px solid var(--neutral-border);position:sticky;top:0;z-index:100;box-shadow:0 1px 3px #0000000d}.header-content{max-width:1400px;margin:0 auto;padding:var(--spacing-lg);width:100%;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:var(--spacing-md)}.header h1{font-size:1.875rem;margin:0;color:var(--primary)}.header-right{display:flex;align-items:center;gap:var(--spacing-lg)}.user-info{color:var(--text-secondary);font-size:.875rem;font-weight:500}.nav{display:flex;gap:var(--spacing-md)}.nav-btn{background:transparent;color:var(--text-secondary);padding:var(--spacing-sm) var(--spacing-lg);border-bottom:3px solid transparent;border-radius:0;font-weight:500;transition:all .2s ease}.nav-btn:hover{color:var(--text-primary);background:var(--neutral-bg)}.nav-btn.active{color:var(--secondary);border-bottom-color:var(--secondary)}.nav-btn.logout{color:var(--error);border:1px solid var(--error);border-radius:6px;padding:var(--spacing-sm) var(--spacing-md)}.nav-btn.logout:hover{background:var(--error);color:#fff}.main{flex:1;max-width:1400px;margin:0 auto;padding:var(--spacing-xl);width:100%;min-width:0;overflow-x:hidden}.loading{text-align:center;padding:var(--spacing-2xl);color:var(--text-secondary);font-size:1.125rem}@media (max-width: 768px){.header-content{padding:var(--spacing-md)}.header h1{font-size:1.5rem;margin-bottom:var(--spacing-md)}.main{padding:var(--spacing-md)}.nav{gap:var(--spacing-sm)}.nav-btn{padding:var(--spacing-sm) var(--spacing-md)}}*{margin:0;padding:0;box-sizing:border-box}:root{--primary: #1f2937;--primary-dark: #111827;--primary-light: #374151;--secondary: #3b82f6;--secondary-light: #60a5fa;--success: #10b981;--warning: #f59e0b;--error: #ef4444;--neutral-bg: #f9fafb;--neutral-border: #e5e7eb;--text-primary: #1f2937;--text-secondary: #6b7280;--spacing-xs: .5rem;--spacing-sm: .75rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem}html{font-size:16px;overflow-x:hidden}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;background-color:var(--neutral-bg);color:var(--text-primary);line-height:1.5;overflow-x:hidden;width:100%}button{cursor:pointer;font-family:inherit;border:none;border-radius:.375rem;padding:var(--spacing-sm) var(--spacing-md);font-size:.875rem;font-weight:500;transition:all .2s ease}button:hover{opacity:.9;transform:translateY(-1px)}button:active{transform:translateY(0)}input,select,textarea{font-family:inherit;border:1px solid var(--neutral-border);border-radius:.375rem;padding:var(--spacing-sm) var(--spacing-md);font-size:.875rem}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--secondary);box-shadow:0 0 0 3px #3b82f61a}table{border-collapse:collapse;width:100%}th{text-align:left;font-weight:600;padding:var(--spacing-md);background-color:var(--neutral-bg);border-bottom:2px solid var(--neutral-border)}td{padding:var(--spacing-md);border-bottom:1px solid var(--neutral-border)}tr:hover{background-color:#f3f4f6}h1,h2,h3{font-weight:600;line-height:1.2;margin-bottom:var(--spacing-md)}h1{font-size:1.875rem}h2{font-size:1.5rem}h3{font-size:1.25rem}p{color:var(--text-secondary);margin-bottom:var(--spacing-md)}
