@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&family=JetBrains+Mono:wght@400;500;600&display=swap";
:root{--ppa-navy:#1b2a4a;--ppa-navy-deep:#263056;--ppa-navy-hero:#2d3e6b;--ppa-blue-mid:#4a6fa5;--ppa-blue-light:#6b8ec4;--ppa-blue-pale:#b8cce4;--ppa-crimson:#c8102e;--ppa-crimson-dark:#8b2332;--ppa-crimson-light:#d94452;--ppa-white:#fff;--ppa-gray-50:#f5f6f8;--ppa-gray-100:#e8ebf0;--ppa-gray-200:#d1d5de;--ppa-gray-300:#b0b7c5;--ppa-gray-400:#8c95a6;--ppa-gray-500:#6b7280;--ppa-gray-600:#4b5563;--ppa-gray-700:#3d4555;--ppa-gray-800:#1f2937;--ppa-gray-900:#111827;--color-success:#10b981;--color-success-light:#d1fae5;--color-success-dark:#059669;--color-warning:#f59e0b;--color-warning-light:#fef3c7;--color-warning-dark:#d97706;--color-danger:#c8102e;--color-danger-light:#fee2e2;--color-danger-dark:#8b2332;--color-info:#4a6fa5;--color-info-light:#dbeafe;--color-info-dark:#2d3e6b;--font-sans:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono:"JetBrains Mono", "SF Mono", "Fira Code", monospace;--text-xs:.75rem;--text-sm:.875rem;--text-base:1rem;--text-lg:1.125rem;--text-xl:1.25rem;--text-2xl:1.5rem;--text-3xl:1.875rem;--text-4xl:2.25rem;--leading-tight:1.25;--leading-normal:1.5;--leading-relaxed:1.625;--space-1:.25rem;--space-2:.5rem;--space-3:.75rem;--space-4:1rem;--space-5:1.25rem;--space-6:1.5rem;--space-8:2rem;--space-10:2.5rem;--space-12:3rem;--space-16:4rem;--radius-sm:6px;--radius-md:8px;--radius-lg:12px;--radius-xl:16px;--radius-2xl:20px;--radius-full:9999px;--shadow-sm:0 1px 2px #1b2a4a0d;--shadow-md:0 4px 6px -1px #1b2a4a12, 0 2px 4px #1b2a4a0a;--shadow-lg:0 10px 15px -3px #1b2a4a14, 0 4px 6px #1b2a4a0a;--shadow-xl:0 20px 25px -5px #1b2a4a1a, 0 8px 10px #1b2a4a0a;--shadow-card:0 1px 3px #1b2a4a0f, 0 1px 2px #1b2a4a0a;--shadow-card-hover:0 8px 25px -5px #1b2a4a1f, 0 4px 10px #1b2a4a0f;--transition-fast:.15s cubic-bezier(.4, 0, .2, 1);--transition-base:.2s cubic-bezier(.4, 0, .2, 1);--transition-slow:.3s cubic-bezier(.4, 0, .2, 1);--transition-spring:.4s cubic-bezier(.34, 1.56, .64, 1);--z-dropdown:10;--z-sticky:20;--z-fixed:30;--z-modal:40;--z-toast:50;--nav-height:64px;--bottom-nav:72px;--sidebar-width:260px;--max-width:1200px;--content-padding:var(--space-4)}[data-theme=dark]{--ppa-white:#0f1729;--ppa-gray-50:#131d33;--ppa-gray-100:#1a2540;--ppa-gray-200:#243052;--ppa-gray-700:#cbd5e1;--ppa-gray-800:#e2e8f0;--ppa-gray-900:#f1f5f9;--shadow-sm:0 1px 2px #0000004d;--shadow-md:0 4px 6px #0000004d;--shadow-lg:0 10px 15px #0000004d;--shadow-card:0 1px 3px #0000004d}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-text-size-adjust:100%;font-size:16px}body{font-family:var(--font-sans);font-size:var(--text-base);line-height:var(--leading-normal);color:var(--ppa-gray-800);background-color:var(--ppa-gray-50);min-height:100dvh;overflow-x:hidden}h1,h2,h3,h4,h5,h6{font-weight:700;line-height:var(--leading-tight);color:var(--ppa-navy);letter-spacing:-.01em}h1{font-size:var(--text-3xl)}h2{font-size:var(--text-2xl)}h3{font-size:var(--text-xl)}h4{font-size:var(--text-lg)}p{color:var(--ppa-gray-600);line-height:var(--leading-relaxed)}a{color:var(--ppa-blue-mid);transition:color var(--transition-fast);text-decoration:none}a:hover{color:var(--ppa-navy-hero)}.mono{font-family:var(--font-mono)}.text-muted{color:var(--ppa-gray-400)}.text-navy{color:var(--ppa-navy)}.text-crimson{color:var(--ppa-crimson)}.container{width:100%;max-width:var(--max-width);padding:0 var(--content-padding);margin:0 auto}.consumer-shell{background:var(--ppa-gray-50);max-width:480px;min-height:100dvh;margin:0 auto;position:relative}@media (min-width:481px){.consumer-shell{box-shadow:-1px 0 0 var(--ppa-gray-200), 1px 0 0 var(--ppa-gray-200), 0 0 40px #1b2a4a0a}.consumer-shell~.bottom-nav,.consumer-shell .bottom-nav{max-width:480px;left:50%;transform:translate(-50%)}}.page{padding-top:var(--space-6);padding-bottom:calc(var(--bottom-nav) + var(--space-6));min-height:100dvh}.flex{display:flex}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.items-start{align-items:flex-start}.items-end{align-items:flex-end}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.justify-end{justify-content:flex-end}.gap-1{gap:var(--space-1)}.gap-2{gap:var(--space-2)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}.gap-6{gap:var(--space-6)}.gap-8{gap:var(--space-8)}.grid{display:grid}.grid-cols-2{grid-template-columns:repeat(2,1fr)}.grid-cols-3{grid-template-columns:repeat(3,1fr)}.grid-cols-4{grid-template-columns:repeat(4,1fr)}.card{background:var(--ppa-white);border:1px solid var(--ppa-gray-100);border-radius:var(--radius-xl);box-shadow:var(--shadow-card);padding:var(--space-5);transition:box-shadow var(--transition-base), transform var(--transition-base)}.card:hover{box-shadow:var(--shadow-card-hover)}.card-interactive:hover{cursor:pointer;transform:translateY(-1px)}.card-interactive:active{transform:translateY(0)scale(.995)}.card-header{margin-bottom:var(--space-4);justify-content:space-between;align-items:center;display:flex}.card-title{font-size:var(--text-lg);color:var(--ppa-navy);font-weight:600}.card-subtitle{font-size:var(--text-sm);color:var(--ppa-gray-400);margin-top:var(--space-1)}.btn{justify-content:center;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);font-family:var(--font-sans);font-size:var(--text-sm);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-base);white-space:nowrap;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;border:none;font-weight:600;line-height:1;display:inline-flex}.btn:active{transform:scale(.97)}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-primary{background:linear-gradient(135deg, var(--ppa-crimson-light), var(--ppa-crimson));color:var(--ppa-white);box-shadow:0 6px 16px #c8102e42}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg, var(--ppa-crimson), var(--ppa-crimson-dark));transform:translateY(-1px);box-shadow:0 10px 22px #c8102e66}.btn-secondary{background:linear-gradient(135deg, var(--ppa-navy-hero), var(--ppa-navy));color:var(--ppa-white);box-shadow:0 6px 16px #1b2a4a3d}.btn-secondary:hover:not(:disabled){background:linear-gradient(135deg, var(--ppa-navy), var(--ppa-navy-deep));transform:translateY(-1px);box-shadow:0 10px 22px #1b2a4a57}.btn-outline{color:var(--ppa-navy);border:1.5px solid var(--ppa-gray-200);background:0 0}.btn-outline:hover:not(:disabled){border-color:var(--ppa-navy);background:#1b2a4a0a}.btn-ghost{color:var(--ppa-gray-600);background:0 0}.btn-ghost:hover:not(:disabled){background:var(--ppa-gray-100);color:var(--ppa-navy)}.btn-success{background:var(--color-success);color:#fff}.btn-success:hover:not(:disabled){background:var(--color-success-dark)}.btn-sm{padding:var(--space-2) var(--space-3);font-size:var(--text-xs)}.btn-lg{padding:var(--space-4) var(--space-8);font-size:var(--text-base);border-radius:var(--radius-lg)}.btn-full{width:100%}.btn-icon{padding:var(--space-2);border-radius:var(--radius-md)}.input-group{gap:var(--space-2);flex-direction:column;display:flex}.input-label{font-size:var(--text-sm);color:var(--ppa-gray-700);font-weight:500}.input{width:100%;padding:var(--space-3) var(--space-4);font-family:var(--font-sans);font-size:var(--text-base);color:var(--ppa-gray-800);background:var(--ppa-white);border:1.5px solid var(--ppa-gray-200);border-radius:var(--radius-md);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);outline:none}.input::placeholder{color:var(--ppa-gray-400)}.input:focus{border-color:var(--ppa-blue-mid);box-shadow:0 0 0 3px #4a6fa526}.input:invalid:not(:placeholder-shown),.input-error{border-color:var(--color-danger)}.input-help{font-size:var(--text-xs);color:var(--ppa-gray-400)}.input-error-text{font-size:var(--text-xs);color:var(--color-danger)}.badge{align-items:center;gap:var(--space-1);padding:2px var(--space-2);font-size:var(--text-xs);border-radius:var(--radius-full);white-space:nowrap;font-weight:600;line-height:1.4;display:inline-flex}.badge-success{background:var(--color-success-light);color:var(--color-success-dark)}.badge-warning{background:var(--color-warning-light);color:var(--color-warning-dark)}.badge-danger{background:var(--color-danger-light);color:var(--color-danger-dark)}.badge-info{background:var(--color-info-light);color:var(--color-info-dark)}.badge-neutral{background:var(--ppa-gray-100);color:var(--ppa-gray-600)}.badge-dot{border-radius:var(--radius-full);flex-shrink:0;width:6px;height:6px}.badge-success .badge-dot{background:var(--color-success)}.badge-warning .badge-dot{background:var(--color-warning)}.badge-danger .badge-dot{background:var(--color-danger)}.badge-info .badge-dot{background:var(--color-info)}.bottom-nav{height:var(--bottom-nav);background:var(--ppa-white);border-top:1px solid var(--ppa-gray-100);z-index:var(--z-fixed);padding-bottom:env(safe-area-inset-bottom,0);-webkit-backdrop-filter:blur(20px);justify-content:space-around;align-items:stretch;display:flex;position:fixed;bottom:0;left:0;right:0}.bottom-nav-item{padding:var(--space-2);color:var(--ppa-gray-400);transition:color var(--transition-fast);-webkit-tap-highlight-color:transparent;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:2px;font-size:10px;font-weight:500;text-decoration:none;display:flex;position:relative}.bottom-nav-item svg{width:22px;height:22px;transition:transform var(--transition-spring)}.bottom-nav-item.active{color:var(--ppa-crimson)}.bottom-nav-item.active svg{transform:scale(1.1)}.bottom-nav-item:active svg{transform:scale(.9)}.sidebar{width:var(--sidebar-width);background:radial-gradient(300px 200px at 50% 0%, #c8102e2e, transparent 70%), linear-gradient(180deg, var(--ppa-navy-deep) 0%, var(--ppa-navy) 55%, #15213d 100%);color:#fff;z-index:var(--z-fixed);flex-direction:column;display:flex;position:fixed;top:0;bottom:0;left:0;overflow-y:auto}.sidebar-logo{padding:var(--space-6) var(--space-5);border-bottom:1px solid #ffffff14}.sidebar-nav{padding:var(--space-4) var(--space-3);gap:var(--space-1);flex-direction:column;flex:1;display:flex}.sidebar-item{align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-3);border-radius:var(--radius-md);color:var(--ppa-blue-pale);font-size:var(--text-sm);transition:all var(--transition-fast);font-weight:500;text-decoration:none;display:flex}.sidebar-item:hover{color:#fff;background:#ffffff14}.sidebar-item.active{color:#fff;background:#ffffff1f}.sidebar-item svg{flex-shrink:0;width:20px;height:20px}.sidebar-section{font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.05em;color:var(--ppa-blue-mid);padding:var(--space-4) var(--space-3) var(--space-2);font-weight:600}.stat-card{background:var(--ppa-white);border:1px solid var(--ppa-gray-100);border-radius:var(--radius-xl);padding:var(--space-5);box-shadow:var(--shadow-card);transition:box-shadow var(--transition-base), transform var(--transition-base)}.stat-card:hover{box-shadow:var(--shadow-card-hover);transform:translateY(-2px)}.stat-card-label{font-size:var(--text-sm);color:var(--ppa-gray-400);margin-bottom:var(--space-1);font-weight:500}.stat-card-value{font-size:var(--text-3xl);color:var(--ppa-navy);font-weight:800;font-family:var(--font-mono);letter-spacing:-.02em}.stat-card-trend{font-size:var(--text-xs);margin-top:var(--space-2);align-items:center;gap:2px;font-weight:600;display:inline-flex}.stat-card-trend.up{color:var(--color-success)}.stat-card-trend.down{color:var(--color-danger)}.capacity-bar{background:var(--ppa-gray-100);border-radius:var(--radius-full);width:100%;height:8px;overflow:hidden}.capacity-bar-fill{border-radius:var(--radius-full);height:100%;transition:width var(--transition-slow)}.capacity-bar-fill.low{background:var(--color-success)}.capacity-bar-fill.medium{background:var(--color-warning)}.capacity-bar-fill.high{background:var(--color-danger)}.data-table{border-collapse:separate;border-spacing:0;width:100%}.data-table th{font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.04em;color:var(--ppa-gray-400);text-align:left;padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--ppa-gray-100);font-weight:600}.data-table td{font-size:var(--text-sm);padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--ppa-gray-100);color:var(--ppa-gray-700)}.data-table tbody tr:hover{background:var(--ppa-gray-50)}.payment-item{align-items:center;gap:var(--space-4);padding:var(--space-4) 0;border-bottom:1px solid var(--ppa-gray-100);transition:background var(--transition-fast);display:flex}.payment-item:last-child{border-bottom:none}.payment-icon{border-radius:var(--radius-full);width:40px;height:40px;font-size:var(--text-lg);flex-shrink:0;justify-content:center;align-items:center;display:flex}.payment-icon.paid{background:var(--color-success-light);color:var(--color-success)}.payment-icon.pending{background:var(--color-warning-light);color:var(--color-warning)}.payment-icon.overdue{background:var(--color-danger-light);color:var(--color-danger)}.payment-details{flex:1;min-width:0}.payment-title{font-size:var(--text-sm);color:var(--ppa-navy);font-weight:600}.payment-subtitle{font-size:var(--text-xs);color:var(--ppa-gray-400);margin-top:1px}.payment-amount{font-family:var(--font-mono);font-size:var(--text-base);color:var(--ppa-navy);text-align:right;font-weight:600}.payment-amount.credit{color:var(--color-success)}.empty-state{padding:var(--space-16) var(--space-8);text-align:center;flex-direction:column;justify-content:center;align-items:center;display:flex}.empty-state-icon{border-radius:var(--radius-full);background:var(--ppa-gray-100);width:64px;height:64px;margin-bottom:var(--space-4);font-size:var(--text-2xl);justify-content:center;align-items:center;display:flex}.empty-state-title{font-size:var(--text-lg);color:var(--ppa-navy);margin-bottom:var(--space-2);font-weight:600}.empty-state-desc{font-size:var(--text-sm);color:var(--ppa-gray-400);max-width:320px}.modal-backdrop{-webkit-backdrop-filter:blur(4px);z-index:var(--z-modal);animation:fadeIn var(--transition-base) ease-out;background:#1b2a4a80;justify-content:center;align-items:flex-end;display:flex;position:fixed;inset:0}.modal{background:var(--ppa-white);border-radius:var(--radius-2xl) var(--radius-2xl) 0 0;width:100%;max-width:500px;max-height:90dvh;padding:var(--space-6);animation:slideUp var(--transition-slow) ease-out;overflow-y:auto}.modal-handle{background:var(--ppa-gray-200);border-radius:var(--radius-full);width:36px;height:4px;margin:0 auto var(--space-5)}@media (min-width:640px){.modal-backdrop{align-items:center}.modal{border-radius:var(--radius-xl);max-height:80dvh}}.toast{top:var(--space-4);z-index:var(--z-toast);background:var(--ppa-navy);color:#fff;padding:var(--space-3) var(--space-5);border-radius:var(--radius-full);font-size:var(--text-sm);box-shadow:var(--shadow-xl);animation:toastIn var(--transition-spring) ease-out;align-items:center;gap:var(--space-2);font-weight:500;display:flex;position:fixed;left:50%;transform:translate(-50%)}.skeleton{background:linear-gradient(90deg, var(--ppa-gray-100) 25%, var(--ppa-gray-50) 50%, var(--ppa-gray-100) 75%);border-radius:var(--radius-md);background-size:200% 100%;animation:1.5s infinite shimmer}.skeleton-text{height:14px;margin-bottom:var(--space-2)}.skeleton-title{width:60%;height:24px;margin-bottom:var(--space-3)}.skeleton-avatar{border-radius:var(--radius-full);width:40px;height:40px}.page-header{background:radial-gradient(460px 220px at 90% -50%, #c8102e66, transparent 70%), linear-gradient(135deg, var(--ppa-navy) 0%, var(--ppa-navy-hero) 55%, var(--ppa-blue-mid) 125%);color:#fff;padding:calc(var(--space-8) + 26px) var(--content-padding) var(--space-8);margin:calc(-1 * var(--space-6)) calc(-1 * var(--content-padding)) var(--space-4);border-bottom-left-radius:var(--radius-2xl);border-bottom-right-radius:var(--radius-2xl);position:relative;box-shadow:0 14px 34px -16px #1b2a4a80}.page-header h1{color:#fff;font-size:var(--text-2xl);margin-bottom:var(--space-1)}.page-header p{color:var(--ppa-blue-pale);font-size:var(--text-sm)}.admin-hero{margin-bottom:var(--space-6);padding:var(--space-6);border-radius:var(--radius-xl);background:radial-gradient(360px 170px at 92% -30%, #c8102e66, transparent 70%), linear-gradient(135deg, var(--ppa-navy) 0%, var(--ppa-navy-hero) 60%, var(--ppa-blue-mid) 135%);color:#fff;position:relative;overflow:hidden;box-shadow:0 14px 30px -16px #1b2a4a80}.admin-hero h1{color:#fff;font-size:var(--text-3xl);margin-bottom:var(--space-1)}.admin-hero p{color:var(--ppa-blue-pale);font-size:var(--text-sm)}.divider{background:var(--ppa-gray-100);height:1px;margin:var(--space-4) 0;border:none}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}@keyframes toastIn{0%{opacity:0;transform:translate(-50%)translateY(-20px)scale(.95)}to{opacity:1;transform:translate(-50%)translateY(0)scale(1)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.stagger-in>*{opacity:0;animation:.4s ease-out forwards fadeInUp}.stagger-in>:first-child{animation-delay:0s}.stagger-in>:nth-child(2){animation-delay:60ms}.stagger-in>:nth-child(3){animation-delay:.12s}.stagger-in>:nth-child(4){animation-delay:.18s}.stagger-in>:nth-child(5){animation-delay:.24s}.stagger-in>:nth-child(6){animation-delay:.3s}@media (max-width:639px){:root{--content-padding:var(--space-4)}h1{font-size:var(--text-2xl)}h2{font-size:var(--text-xl)}.hide-mobile{display:none!important}.grid-cols-2,.grid-cols-3,.grid-cols-4{grid-template-columns:repeat(2,1fr)}}@media (min-width:640px){.hide-desktop{display:none!important}}@media (min-width:1024px){:root{--content-padding:var(--space-8)}}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--ppa-gray-200);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--ppa-gray-300)}:focus-visible{outline:2px solid var(--ppa-blue-mid);outline-offset:2px}::selection{color:var(--ppa-navy);background:#4a6fa533}body:not(.dev-tools-open) div[style*=z-index][style*="2147483647"]:not(#demo-drawer),body:not(.dev-tools-open) div[class*=StripeTestMode],body:not(.dev-tools-open) iframe[title*="Stripe Elements Testing"],body:not(.dev-tools-open) nextjs-portal{opacity:0!important;pointer-events:none!important;transform:translate(200%)scale(.5)!important}body.dev-tools-open div[style*=z-index][style*="2147483647"]:not(#demo-drawer),body.dev-tools-open div[class*=StripeTestMode],body.dev-tools-open iframe[title*="Stripe Elements Testing"],body.dev-tools-open nextjs-portal{transition:transform var(--transition-spring), opacity var(--transition-base)!important;opacity:1!important;pointer-events:auto!important;transform:translate(0)scale(1)!important}
