/* AK Fintech Theme — theme.css */
:root{--akft-sidebar-w:260px;--akft-topbar-h:60px;--akft-accent:#4F46E5;--akft-primary:#0F172A;--akft-surface:#F8FAFC;--akft-border:#E2E8F0;--akft-radius:16px;--akft-shadow:0 1px 3px rgba(0,0,0,.07),0 1px 2px rgba(0,0,0,.05);--akft-shadow-md:0 4px 12px rgba(0,0,0,.08);--akft-shadow-lg:0 10px 30px rgba(0,0,0,.1)}
*,*::before,*::after{box-sizing:border-box}html{scroll-behavior:smooth}body.akft-app{background:var(--akft-surface);color:var(--akft-primary)}img{max-width:100%;height:auto}
.no-scrollbar::-webkit-scrollbar{display:none}.no-scrollbar{-ms-overflow-style:none;scrollbar-width:none}
/* Hero */
.hero-grid{background-image:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);background-size:48px 48px}
/* Service tiles */
.akft-services-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}
@media(min-width:480px){.akft-services-grid{grid-template-columns:repeat(4,1fr)}}
@media(min-width:768px){.akft-services-grid{grid-template-columns:repeat(5,1fr);gap:14px}}
@media(min-width:1024px){.akft-services-grid{grid-template-columns:repeat(5,1fr);gap:16px}}
.akft-service-tile{display:flex;flex-direction:column;align-items:center;gap:10px;padding:16px 10px;background:#fff;border:1.5px solid var(--akft-border);border-radius:var(--akft-radius);text-decoration:none;transition:border-color .2s,box-shadow .2s,transform .15s;cursor:pointer;position:relative;text-align:center}
.akft-service-tile:hover{border-color:rgba(79,70,229,.35);box-shadow:var(--akft-shadow-md);transform:translateY(-2px)}
.akft-service-tile .tile-icon{width:52px;height:52px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:24px;transition:transform .2s;flex-shrink:0}
.akft-service-tile:hover .tile-icon{transform:scale(1.1)}
.akft-service-tile .tile-label{font-size:12px;font-weight:600;color:#334155;line-height:1.3}
.akft-service-tile .tile-badge{position:absolute;top:7px;right:7px;font-size:9px;font-weight:700;padding:2px 6px;border-radius:999px}
/* Dashboard app shell */
.akft-app-shell{display:flex;min-height:100vh;background:var(--akft-surface)}
/* Sidebar */
.akft-sidebar{width:var(--akft-sidebar-w);background:#fff;border-right:1px solid var(--akft-border);display:flex;flex-direction:column;position:sticky;top:0;height:100vh;overflow-y:auto;flex-shrink:0;transition:transform .3s cubic-bezier(.4,0,.2,1);z-index:50}
@media(max-width:1023px){.akft-sidebar{position:fixed;left:0;top:0;transform:translateX(-100%);box-shadow:var(--akft-shadow-lg)}.akft-sidebar.is-open{transform:translateX(0)}}
.akft-sidebar-logo{display:flex;align-items:center;gap:10px;padding:18px 18px 14px;border-bottom:1px solid var(--akft-border);text-decoration:none;flex-shrink:0}
.akft-sidebar-nav{flex:1;padding:10px;overflow-y:auto}
.akft-nav-section{font-size:10px;font-weight:700;color:#94a3b8;text-transform:uppercase;letter-spacing:.08em;padding:12px 10px 6px}
.akft-nav-link{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:12px;font-size:13.5px;font-weight:500;color:#475569;text-decoration:none;transition:background .15s,color .15s;margin-bottom:2px;white-space:nowrap}
.akft-nav-link svg{width:18px;height:18px;flex-shrink:0;opacity:.7;transition:opacity .15s}
.akft-nav-link:hover{background:#f1f5f9;color:#1e293b}.akft-nav-link:hover svg{opacity:1}
.akft-nav-link.active{background:#ede9fe;color:var(--akft-accent);font-weight:600}.akft-nav-link.active svg{opacity:1}
.akft-sidebar-wallet{margin:10px;padding:14px 16px;background:linear-gradient(135deg,var(--akft-accent),#7c3aed);border-radius:14px;color:#fff;flex-shrink:0}
.akft-sidebar-footer{padding:12px;border-top:1px solid var(--akft-border);flex-shrink:0}
/* Main area */
.akft-main-area{flex:1;min-width:0;display:flex;flex-direction:column}
.akft-topbar{height:var(--akft-topbar-h);background:#fff;border-bottom:1px solid var(--akft-border);display:flex;align-items:center;padding:0 16px;gap:12px;position:sticky;top:0;z-index:40;flex-shrink:0}
@media(min-width:1024px){.akft-topbar{padding:0 28px}}
.akft-sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(15,23,42,.4);backdrop-filter:blur(2px);z-index:49}
@media(max-width:1023px){.akft-sidebar-overlay.visible{display:block}}
.akft-page-content{flex:1;padding:16px;max-width:1200px;width:100%;margin:0 auto}
@media(min-width:640px){.akft-page-content{padding:20px 24px}}
@media(min-width:1280px){.akft-page-content{padding:28px 40px}}
/* Stats grid */
.akft-stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
@media(min-width:640px){.akft-stats-grid{grid-template-columns:repeat(3,1fr);gap:16px}}
@media(min-width:1024px){.akft-stats-grid{grid-template-columns:repeat(4,1fr)}}
/* Cards */
.akft-card{background:#fff;border:1px solid var(--akft-border);border-radius:var(--akft-radius);padding:18px;box-shadow:var(--akft-shadow)}
/* Inputs */
.input-field{display:block;width:100%;height:50px;padding:0 14px;border:1.5px solid var(--akft-border);border-radius:14px;font-size:15px;color:var(--akft-primary);background:#fff;transition:border-color .2s,box-shadow .2s;outline:none;-webkit-appearance:none;font-family:inherit}
.input-field:focus{border-color:var(--akft-accent);box-shadow:0 0 0 3px rgba(79,70,229,.12)}
.input-field::placeholder{color:#94a3b8}
select.input-field{padding-right:40px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%2394a3b8' stroke-width='2'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' d='M19 9l-7 7-7-7'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;background-size:16px;cursor:pointer}
/* Buttons */
.btn-primary{display:inline-flex;align-items:center;justify-content:center;gap:8px;height:50px;padding:0 24px;background:var(--akft-accent);color:#fff;font-size:15px;font-weight:600;border:none;border-radius:14px;cursor:pointer;transition:background .2s,transform .1s,box-shadow .2s;text-decoration:none;box-shadow:0 4px 14px rgba(79,70,229,.35);font-family:inherit}
.btn-primary:hover{background:#4338ca;transform:translateY(-1px);box-shadow:0 6px 20px rgba(79,70,229,.45)}
.btn-primary:active{transform:translateY(0)}.btn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none}
.btn-primary.w-full{width:100%}
.btn-outline{display:inline-flex;align-items:center;justify-content:center;gap:8px;height:50px;padding:0 24px;background:#fff;color:#475569;font-size:15px;font-weight:600;border:1.5px solid var(--akft-border);border-radius:14px;cursor:pointer;transition:border-color .2s,color .2s;text-decoration:none;font-family:inherit}
.btn-outline:hover{border-color:var(--akft-accent);color:var(--akft-accent)}.btn-outline.w-full{width:100%}
/* Plan cards */
.akft-plan-card{display:flex;align-items:center;gap:12px;padding:12px 14px;border:1.5px solid var(--akft-border);border-radius:14px;background:#fff;cursor:pointer;transition:border-color .2s,background .2s}
.akft-plan-card:hover{border-color:rgba(79,70,229,.4);background:#faf9ff}
.akft-plan-card.selected{border-color:var(--akft-accent);background:#ede9fe}
/* Payment modal */
.akft-modal-backdrop{position:fixed;inset:0;background:rgba(15,23,42,.65);backdrop-filter:blur(4px);z-index:9000;display:flex;align-items:flex-end;justify-content:center}
@media(min-width:640px){.akft-modal-backdrop{align-items:center;padding:20px}}
.akft-modal{background:#fff;width:100%;max-width:440px;border-radius:24px 24px 0 0;overflow:hidden;position:relative;max-height:95vh;display:flex;flex-direction:column;animation:modalSlideUp .3s cubic-bezier(.4,0,.2,1)}
@media(min-width:640px){.akft-modal{border-radius:24px;animation:modalScale .25s cubic-bezier(.4,0,.2,1);max-height:90vh}}
@keyframes modalSlideUp{from{transform:translateY(100%)}to{transform:translateY(0)}}
@keyframes modalScale{from{transform:scale(.95);opacity:0}to{transform:scale(1);opacity:1}}
.akft-modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px 12px;border-bottom:1px solid var(--akft-border);flex-shrink:0}
.akft-modal-body{flex:1;overflow-y:auto;padding:20px;-webkit-overflow-scrolling:touch}
.akft-modal-footer{padding:14px 20px;border-top:1px solid var(--akft-border);flex-shrink:0;background:#fff}
#akft-qr-container{display:flex;align-items:center;justify-content:center;padding:20px;background:#fff;border-radius:16px;border:1.5px solid var(--akft-border);min-height:260px}
#akft-qr-container img,#akft-qr-container canvas{border-radius:8px;max-width:220px!important;max-height:220px!important}
/* Badges */
.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:999px;font-size:11px;font-weight:700}
.badge-ok,.badge-success{background:#dcfce7;color:#16a34a}
.badge-err,.badge-failed{background:#fee2e2;color:#dc2626}
.badge-warn,.badge-pending{background:#fef3c7;color:#d97706}
/* Table */
.akft-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:var(--akft-radius);border:1px solid var(--akft-border)}
.akft-table{width:100%;border-collapse:collapse;min-width:480px}
.akft-table th{text-align:left;font-size:11px;font-weight:700;color:#94a3b8;text-transform:uppercase;letter-spacing:.06em;padding:10px 14px;border-bottom:1px solid var(--akft-border);white-space:nowrap}
.akft-table td{padding:14px;font-size:14px;border-bottom:1px solid #f1f5f9;color:#334155;vertical-align:middle}
.akft-table tr:last-child td{border-bottom:none}.akft-table tbody tr:hover td{background:#fafafa}
/* Animations */
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes fadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
@keyframes popIn{from{transform:scale(0);opacity:0}to{transform:scale(1);opacity:1}}
@keyframes shimmer{from{background-position:-400px 0}to{background-position:400px 0}}
@keyframes dotPulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.8)}}
.spin{animation:spin 1s linear infinite}
.fade-in{animation:fadeIn .4s ease-out}
.pop-in{animation:popIn .4s cubic-bezier(.34,1.56,.64,1)}
.skeleton{background:linear-gradient(90deg,#f1f5f9 25%,#e2e8f0 37%,#f1f5f9 63%);background-size:800px 100%;animation:shimmer 1.4s ease-in-out infinite;border-radius:8px}
.status-dot-pending{animation:dotPulse 1.5s ease-in-out infinite}
/* Bottom nav (mobile only) */
.akft-bottom-nav{display:flex}
@media(min-width:1024px){.akft-bottom-nav{display:none!important}}
/* Responsive helpers */
@media(max-width:639px){.hide-mobile{display:none!important}}
@media(min-width:1024px){.hide-desktop{display:none!important}}
/* Print */
@media print{.no-print,.akft-sidebar,.akft-topbar,.akft-bottom-nav{display:none!important}.akft-main-area{padding:0}}
