/* ================================================================
   Hospital QR Management System — Professional Light Theme
   Font: Inter (Google Fonts) | Design: SaaS Corporate 2025
   ================================================================ */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap');

:root {
  --primary:        #2563EB;
  --primary-light:  #EFF6FF;
  --primary-dark:   #1D4ED8;
  --accent:         #0EA5E9;
  --accent-light:   #F0F9FF;
  --success:        #10B981;
  --success-light:  #ECFDF5;
  --warning:        #F59E0B;
  --warning-light:  #FFFBEB;
  --danger:         #EF4444;
  --danger-light:   #FEF2F2;
  --info:           #6366F1;
  --info-light:     #EEF2FF;
  --gray-50:   #F9FAFB;
  --gray-100:  #F3F4F6;
  --gray-200:  #E5E7EB;
  --gray-300:  #D1D5DB;
  --gray-400:  #9CA3AF;
  --gray-500:  #6B7280;
  --gray-600:  #4B5563;
  --gray-700:  #374151;
  --gray-800:  #1F2937;
  --gray-900:  #111827;
  --sidebar-width: 260px;
  --header-height: 64px;
  --radius: 10px;
  --radius-lg: 16px;
  --radius-sm: 6px;
  --shadow-xs: 0 1px 2px rgba(0,0,0,.05);
  --shadow-sm: 0 1px 3px rgba(0,0,0,.08),0 1px 2px rgba(0,0,0,.04);
  --shadow-md: 0 4px 6px rgba(0,0,0,.07),0 2px 4px rgba(0,0,0,.04);
  --shadow-lg: 0 10px 15px rgba(0,0,0,.08),0 4px 6px rgba(0,0,0,.05);
  --shadow-xl: 0 20px 25px rgba(0,0,0,.10),0 8px 10px rgba(0,0,0,.06);
  --tr: all .2s ease;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;font-size:14px;font-weight:400;line-height:1.6;background:var(--gray-50);color:var(--gray-800);-webkit-font-smoothing:antialiased}

h1,h2,h3,h4,h5,h6{font-weight:700;line-height:1.3;color:var(--gray-900);letter-spacing:-0.01em}
h1{font-size:2rem}h2{font-size:1.5rem}h3{font-size:1.25rem}h4{font-size:1.1rem}
p{color:var(--gray-600);line-height:1.7}
a{color:var(--primary);text-decoration:none;transition:var(--tr)}
a:hover{color:var(--primary-dark)}

/* SIDEBAR */
.sidebar{position:fixed;top:0;left:0;width:var(--sidebar-width);height:100vh;background:#fff;border-right:1px solid var(--gray-200);overflow-y:auto;z-index:200;transition:transform .3s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column}
.sidebar-brand{padding:20px 20px 16px;border-bottom:1px solid var(--gray-100);display:flex;align-items:center;gap:12px}
.sidebar-brand .logo-wrap{width:40px;height:40px;background:linear-gradient(135deg,var(--primary) 0%,var(--accent) 100%);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0;box-shadow:0 4px 12px rgba(37,99,235,.25)}
.sidebar-brand .brand-text h4{font-size:14px;font-weight:700;color:var(--gray-900);line-height:1.2}
.sidebar-brand .brand-text small{font-size:11px;color:var(--gray-400);font-weight:400}
.sidebar-nav{padding:12px 12px 0;flex:1}
.nav-section-title{font-size:10px;font-weight:600;color:var(--gray-400);letter-spacing:.08em;text-transform:uppercase;padding:16px 8px 6px}
.sidebar-nav a{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:var(--radius-sm);color:var(--gray-600);font-size:13.5px;font-weight:500;transition:var(--tr);margin-bottom:2px}
.sidebar-nav a:hover{background:var(--gray-100);color:var(--gray-900)}
.sidebar-nav a.active{background:var(--primary-light);color:var(--primary);font-weight:600}
.sidebar-nav a .nav-icon{width:20px;text-align:center;font-size:15px;flex-shrink:0}
.sidebar-footer{padding:12px;border-top:1px solid var(--gray-100)}
.sidebar-footer .user-info{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--radius-sm)}
.sidebar-footer .user-avatar{width:34px;height:34px;background:linear-gradient(135deg,var(--primary) 0%,var(--accent) 100%);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:13px;flex-shrink:0}
.sidebar-footer .user-meta{flex:1;min-width:0}
.sidebar-footer .user-name{font-size:13px;font-weight:600;color:var(--gray-800);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sidebar-footer .user-role{font-size:11px;color:var(--gray-400)}
.logout-link{color:var(--gray-400);font-size:14px;transition:var(--tr)}
.logout-link:hover{color:var(--danger)}

/* HEADER */
.main-header{position:fixed;top:0;left:var(--sidebar-width);right:0;height:var(--header-height);background:#fff;border-bottom:1px solid var(--gray-200);display:flex;align-items:center;padding:0 24px;z-index:100;gap:16px}
.header-title{font-size:18px;font-weight:700;color:var(--gray-900);flex:1}
.header-actions{display:flex;align-items:center;gap:12px}
.header-date{font-size:12.5px;color:var(--gray-400);font-weight:500}
.header-badge{background:var(--primary-light);color:var(--primary);font-size:12px;font-weight:600;padding:5px 12px;border-radius:999px}
#menu-btn{background:none;border:none;font-size:20px;cursor:pointer;color:var(--gray-600);display:none;padding:4px;border-radius:6px}
#menu-btn:hover{background:var(--gray-100)}

/* MAIN CONTENT */
.main-content{margin-left:var(--sidebar-width);margin-top:var(--header-height);padding:28px;min-height:calc(100vh - var(--header-height))}

/* PAGE HEADER */
.page-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:24px;gap:16px;flex-wrap:wrap}
.page-header-left h2{font-size:1.4rem;font-weight:800;color:var(--gray-900)}
.page-header-left p{font-size:13.5px;color:var(--gray-400);margin-top:2px}
.page-header-actions{display:flex;gap:10px;flex-wrap:wrap}

/* CARDS */
.card{background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden}
.card-header{padding:18px 22px;border-bottom:1px solid var(--gray-100);display:flex;align-items:center;justify-content:space-between;gap:12px}
.card-title{font-size:15px;font-weight:700;color:var(--gray-900);display:flex;align-items:center;gap:8px}
.card-body{padding:22px}
.card-footer{padding:14px 22px;background:var(--gray-50);border-top:1px solid var(--gray-100);display:flex;align-items:center;justify-content:space-between;gap:12px}

/* STAT CARDS */
.stat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:18px;margin-bottom:24px}
.stat-card{background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius-lg);padding:22px;display:flex;align-items:flex-start;gap:16px;box-shadow:var(--shadow-sm);transition:var(--tr)}
.stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}
.stat-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0}
.stat-icon.blue{background:var(--primary-light)}.stat-icon.green{background:var(--success-light)}.stat-icon.amber{background:var(--warning-light)}.stat-icon.red{background:var(--danger-light)}.stat-icon.purple{background:var(--info-light)}.stat-icon.cyan{background:var(--accent-light)}
.stat-value{font-size:1.8rem;font-weight:800;color:var(--gray-900);line-height:1}
.stat-label{font-size:13px;color:var(--gray-400);margin-top:4px;font-weight:500}
.stat-change{font-size:12px;font-weight:600;margin-top:6px;display:inline-flex;align-items:center;gap:3px}
.stat-change.up{color:var(--success)}.stat-change.down{color:var(--danger)}

/* TABLES */
.table-responsive{overflow-x:auto;border-radius:var(--radius-lg)}
table{width:100%;border-collapse:collapse;font-size:13.5px}
thead tr{background:var(--gray-50);border-bottom:2px solid var(--gray-200)}
thead th{padding:12px 16px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--gray-400);white-space:nowrap;text-align:left}
tbody tr{border-bottom:1px solid var(--gray-100);transition:var(--tr)}
tbody tr:last-child{border-bottom:none}
tbody tr:hover{background:var(--gray-50)}
tbody td{padding:13px 16px;color:var(--gray-700);vertical-align:middle}
.td-bold{font-weight:600;color:var(--gray-900)}.td-muted{color:var(--gray-400);font-size:12.5px}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;gap:6px;padding:9px 18px;font-size:13.5px;font-weight:600;border:1.5px solid transparent;border-radius:var(--radius-sm);cursor:pointer;transition:var(--tr);white-space:nowrap;font-family:inherit;text-decoration:none;line-height:1}
.btn:disabled{opacity:.55;pointer-events:none}
.btn-primary{background:var(--primary);color:#fff;border-color:var(--primary)}
.btn-primary:hover{background:var(--primary-dark);border-color:var(--primary-dark);color:#fff}
.btn-outline{background:transparent;color:var(--primary);border-color:var(--primary)}
.btn-outline:hover{background:var(--primary-light)}
.btn-success{background:var(--success);color:#fff;border-color:var(--success)}
.btn-success:hover{background:#059669;color:#fff}
.btn-danger{background:var(--danger);color:#fff;border-color:var(--danger)}
.btn-danger:hover{background:#DC2626;color:#fff}
.btn-warning{background:var(--warning);color:#fff;border-color:var(--warning)}
.btn-warning:hover{background:#D97706;color:#fff}
.btn-ghost{background:transparent;color:var(--gray-600);border-color:var(--gray-200)}
.btn-ghost:hover{background:var(--gray-100);color:var(--gray-800)}
.btn-sm{padding:6px 12px;font-size:12.5px}
.btn-lg{padding:12px 24px;font-size:15px}
.btn-block{width:100%;justify-content:center}
.btn-icon{padding:8px;width:34px;height:34px;justify-content:center}

/* FORMS */
.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:18px}
.form-group{margin-bottom:18px}
.form-group label{display:block;font-size:13px;font-weight:600;color:var(--gray-700);margin-bottom:6px}
.form-control{width:100%;padding:10px 14px;font-size:13.5px;border:1.5px solid var(--gray-200);border-radius:var(--radius-sm);background:#fff;color:var(--gray-800);transition:var(--tr);font-family:inherit;outline:none}
.form-control:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(37,99,235,.1)}
.form-control::placeholder{color:var(--gray-400)}
.form-control:read-only{background:var(--gray-50);color:var(--gray-500)}
textarea.form-control{resize:vertical;min-height:90px}
select.form-control{cursor:pointer}
.form-hint{font-size:12px;color:var(--gray-400);margin-top:4px}
.form-error{font-size:12px;color:var(--danger);margin-top:4px;font-weight:500}
.input-group{display:flex;align-items:stretch;border:1.5px solid var(--gray-200);border-radius:var(--radius-sm);overflow:hidden;transition:var(--tr)}
.input-group:focus-within{border-color:var(--primary);box-shadow:0 0 0 3px rgba(37,99,235,.1)}
.input-group .form-control{border:none;box-shadow:none;border-radius:0}
.input-group .input-group-btn{background:var(--gray-50);border:none;border-left:1.5px solid var(--gray-200);padding:0 14px;color:var(--gray-500);cursor:pointer;font-size:15px;transition:var(--tr)}
.input-group .input-group-btn:hover{background:var(--gray-100);color:var(--primary)}

/* BADGES */
.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;font-size:11.5px;font-weight:600;border-radius:999px;white-space:nowrap}
.badge-primary{background:var(--primary-light);color:var(--primary)}
.badge-success{background:var(--success-light);color:var(--success)}
.badge-warning{background:var(--warning-light);color:#B45309}
.badge-danger{background:var(--danger-light);color:var(--danger)}
.badge-info{background:var(--info-light);color:var(--info)}
.badge-gray{background:var(--gray-100);color:var(--gray-600)}

/* ALERTS */
.alert{padding:12px 16px;border-radius:var(--radius-sm);font-size:13.5px;display:flex;align-items:flex-start;gap:10px;margin-bottom:18px;font-weight:500}
.alert-success{background:var(--success-light);color:#065F46;border:1px solid #A7F3D0}
.alert-danger{background:var(--danger-light);color:#991B1B;border:1px solid #FECACA}
.alert-warning{background:var(--warning-light);color:#92400E;border:1px solid #FDE68A}
.alert-info{background:var(--info-light);color:#312E81;border:1px solid #C7D2FE}

/* MODALS */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.4);backdrop-filter:blur(3px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px;animation:fadeIn .15s ease}
.modal{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);width:100%;max-width:540px;max-height:92vh;overflow-y:auto;animation:slideUp .2s cubic-bezier(.34,1.56,.64,1)}
.modal-lg{max-width:740px}.modal-xl{max-width:960px}
.modal-header{padding:20px 24px;border-bottom:1px solid var(--gray-100);display:flex;align-items:center;justify-content:space-between}
.modal-title{font-size:16px;font-weight:700;color:var(--gray-900)}
.modal-close{background:var(--gray-100);border:none;width:30px;height:30px;border-radius:6px;cursor:pointer;font-size:16px;color:var(--gray-500);display:flex;align-items:center;justify-content:center;transition:var(--tr)}
.modal-close:hover{background:var(--gray-200);color:var(--gray-700)}
.modal-body{padding:22px 24px}
.modal-footer{padding:16px 24px;border-top:1px solid var(--gray-100);display:flex;align-items:center;justify-content:flex-end;gap:10px}

/* TABS */
.tabs{display:flex;gap:2px;background:var(--gray-100);padding:4px;border-radius:var(--radius-sm);margin-bottom:22px;overflow-x:auto}
.tab{padding:8px 18px;font-size:13.5px;font-weight:600;color:var(--gray-500);background:transparent;border:none;border-radius:6px;cursor:pointer;transition:var(--tr);white-space:nowrap;font-family:inherit}
.tab:hover{color:var(--gray-700)}
.tab.active{background:#fff;color:var(--primary);box-shadow:var(--shadow-xs)}

/* PATIENT CARD */
.patient-card{background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm)}
.patient-card-header{background:linear-gradient(135deg,var(--primary) 0%,var(--accent) 100%);padding:24px;display:flex;align-items:flex-start;gap:18px}
.patient-avatar{width:60px;height:60px;border-radius:50%;background:rgba(255,255,255,.25);border:3px solid rgba(255,255,255,.6);display:flex;align-items:center;justify-content:center;font-size:26px;flex-shrink:0}
.patient-info-main h3{color:#fff;font-size:18px}
.patient-info-main p{color:rgba(255,255,255,.75);font-size:13px;margin-top:2px}
.patient-id-badge{display:inline-block;background:rgba(255,255,255,.2);color:#fff;font-size:12px;font-weight:700;padding:3px 10px;border-radius:999px;margin-top:8px;letter-spacing:.04em}
.patient-details-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:1px;background:var(--gray-100)}
.patient-detail-item{padding:14px 18px;background:#fff}
.patient-detail-item .detail-label{font-size:10.5px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--gray-400);margin-bottom:3px}
.patient-detail-item .detail-value{font-size:14px;font-weight:600;color:var(--gray-800)}

/* QR BOX */
.qr-box{background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius-lg);padding:24px;text-align:center;box-shadow:var(--shadow-sm)}
.qr-code-wrap{display:inline-block;padding:14px;background:#fff;border:1.5px solid var(--gray-200);border-radius:10px;margin-bottom:12px}
.qr-patient-id{font-family:'Courier New',monospace;font-size:15px;font-weight:700;color:var(--gray-800);letter-spacing:.1em;margin-bottom:4px}

/* TIMELINE */
.timeline{position:relative;padding-left:28px}
.timeline::before{content:'';position:absolute;left:9px;top:0;bottom:0;width:2px;background:var(--gray-200)}
.timeline-item{position:relative;margin-bottom:20px}
.timeline-item::before{content:'';position:absolute;left:-23px;top:4px;width:10px;height:10px;border-radius:50%;background:var(--primary);border:2px solid #fff;box-shadow:0 0 0 2px var(--primary)}
.timeline-date{font-size:11.5px;color:var(--gray-400);font-weight:600;margin-bottom:4px}
.timeline-content{background:var(--gray-50);border:1px solid var(--gray-200);border-radius:var(--radius-sm);padding:12px 16px}

/* SEARCH */
.search-bar{position:relative}
.search-bar input{width:100%;padding:9px 14px 9px 38px;border:1.5px solid var(--gray-200);border-radius:var(--radius-sm);font-size:13.5px;background:#fff;transition:var(--tr);font-family:inherit;outline:none;color:var(--gray-800)}
.search-bar input:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(37,99,235,.1)}
.search-bar .search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--gray-400);font-size:14px;pointer-events:none}

/* LOGIN */
.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#EFF6FF 0%,#F0F9FF 50%,#F5F3FF 100%);padding:20px}
.login-box{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);padding:42px 42px 36px;width:100%;max-width:420px}
.login-logo{text-align:center;margin-bottom:32px}
.login-logo .icon-wrap{width:68px;height:68px;background:linear-gradient(135deg,var(--primary) 0%,var(--accent) 100%);border-radius:18px;margin:0 auto 14px;display:flex;align-items:center;justify-content:center;font-size:30px;box-shadow:0 8px 24px rgba(37,99,235,.3)}
.login-logo h2{font-size:1.4rem;font-weight:800;color:var(--gray-900)}
.login-logo p{font-size:13px;color:var(--gray-400);margin-top:3px}
.demo-credentials{margin-top:20px;background:var(--gray-50);border:1px solid var(--gray-200);border-radius:var(--radius-sm);padding:14px 16px;font-size:12.5px;color:var(--gray-500)}
.demo-credentials strong{display:block;color:var(--gray-700);font-size:12px;margin-bottom:6px;text-transform:uppercase;letter-spacing:.04em}

/* SAAS LANDING */
.saas-page{background:#fff;font-family:'Inter',sans-serif}
.saas-nav{padding:16px 60px;display:flex;align-items:center;justify-content:space-between;background:rgba(255,255,255,.95);backdrop-filter:blur(12px);border-bottom:1px solid var(--gray-200);position:sticky;top:0;z-index:50}
.saas-nav-brand{display:flex;align-items:center;gap:10px}
.saas-nav-brand .logo{width:36px;height:36px;background:linear-gradient(135deg,var(--primary) 0%,var(--accent) 100%);border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:18px}
.saas-nav-brand span{font-size:16px;font-weight:800;color:var(--gray-900)}
.saas-nav-links{display:flex;gap:28px}
.saas-nav-links a{font-size:14px;font-weight:500;color:var(--gray-600)}
.saas-nav-links a:hover{color:var(--primary)}
.saas-nav-cta{display:flex;gap:10px;align-items:center}
.saas-hero{background:linear-gradient(150deg,#EFF6FF 0%,#E0F2FE 50%,#EDE9FE 100%);padding:100px 60px 80px;text-align:center}
.saas-hero-badge{display:inline-flex;align-items:center;gap:6px;background:var(--primary-light);color:var(--primary);font-size:12.5px;font-weight:700;padding:6px 16px;border-radius:999px;margin-bottom:24px;letter-spacing:.02em}
.saas-hero h1{font-size:3.2rem;font-weight:800;color:var(--gray-900);line-height:1.15;margin-bottom:20px;letter-spacing:-0.03em;max-width:800px;margin-left:auto;margin-right:auto}
.saas-hero h1 span{color:var(--primary)}
.saas-hero > p{font-size:1.1rem;max-width:600px;margin:0 auto 40px;color:var(--gray-500);line-height:1.7}
.saas-hero-btns{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-bottom:60px}
.hero-stats{display:flex;gap:40px;justify-content:center;flex-wrap:wrap}
.hero-stat{text-align:center}
.hero-stat .num{font-size:2rem;font-weight:800;color:var(--gray-900)}
.hero-stat .lbl{font-size:13px;color:var(--gray-400);font-weight:500}

.saas-section{padding:80px 60px;max-width:1140px;margin:0 auto}
.saas-section-title{text-align:center;margin-bottom:48px}
.saas-section-title .tag{display:inline-block;background:var(--primary-light);color:var(--primary);font-size:12px;font-weight:700;padding:4px 12px;border-radius:999px;margin-bottom:12px;letter-spacing:.04em}
.saas-section-title h2{font-size:2rem;font-weight:800;letter-spacing:-0.02em}
.saas-section-title p{font-size:1rem;color:var(--gray-400);margin-top:8px;max-width:560px;margin-left:auto;margin-right:auto}

.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px}
.feature-card{background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius-lg);padding:28px;transition:var(--tr)}
.feature-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-3px)}
.feature-icon{width:52px;height:52px;background:var(--primary-light);border-radius:13px;display:flex;align-items:center;justify-content:center;font-size:24px;margin-bottom:18px}
.feature-card h4{font-size:16px;font-weight:700;margin-bottom:8px}
.feature-card p{font-size:13.5px;color:var(--gray-500);line-height:1.65}

.pricing-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:24px;max-width:920px;margin:0 auto}
.pricing-card{background:#fff;border:1.5px solid var(--gray-200);border-radius:var(--radius-lg);padding:36px 28px;text-align:center;transition:var(--tr)}
.pricing-card.featured{border-color:var(--primary);box-shadow:0 0 0 4px rgba(37,99,235,.1),var(--shadow-lg)}
.pricing-card .plan-badge{display:inline-block;background:var(--primary);color:#fff;font-size:11px;font-weight:700;padding:3px 10px;border-radius:999px;margin-bottom:16px;letter-spacing:.04em}
.pricing-card .plan-name{font-size:16px;font-weight:700;color:var(--gray-700);margin-bottom:8px}
.pricing-card .plan-price{font-size:3rem;font-weight:800;color:var(--gray-900);line-height:1}
.pricing-card .plan-price sup{font-size:1.2rem;vertical-align:top;margin-top:8px;display:inline-block}
.pricing-card .plan-period{font-size:13px;color:var(--gray-400);margin-bottom:24px}
.pricing-card ul{list-style:none;margin-bottom:28px;text-align:left}
.pricing-card ul li{padding:7px 0;border-bottom:1px solid var(--gray-100);font-size:13.5px;color:var(--gray-600);display:flex;align-items:center;gap:8px}
.pricing-card ul li:last-child{border-bottom:none}
.pricing-card ul li .check{color:var(--success);font-weight:700;flex-shrink:0}

.saas-footer{background:var(--gray-900);color:var(--gray-400);padding:60px 60px 30px}
.saas-footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:40px;margin-bottom:40px}
.saas-footer h3{font-size:14px;font-weight:700;color:#fff;margin-bottom:16px}
.saas-footer a{display:block;color:var(--gray-400);font-size:13.5px;margin-bottom:8px;transition:var(--tr)}
.saas-footer a:hover{color:#fff}
.saas-footer .footer-brand{font-size:18px;font-weight:800;color:#fff;margin-bottom:10px}
.saas-footer .footer-desc{font-size:13.5px;line-height:1.7}
.saas-footer hr{border:none;border-top:1px solid rgba(255,255,255,.1);margin-bottom:20px}
.saas-footer .footer-bottom{display:flex;justify-content:space-between;font-size:12.5px;flex-wrap:wrap;gap:10px}

/* UTILITIES */
.flex{display:flex}.flex-1{flex:1}.items-center{align-items:center}.items-start{align-items:flex-start}
.justify-between{justify-content:space-between}.justify-end{justify-content:flex-end}
.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}
.grid{display:grid}.col-2{grid-template-columns:1fr 1fr;gap:20px}.col-3{grid-template-columns:1fr 1fr 1fr;gap:20px}
.mb-1{margin-bottom:6px}.mb-2{margin-bottom:12px}.mb-3{margin-bottom:18px}.mb-4{margin-bottom:24px}.mb-5{margin-bottom:32px}
.mt-1{margin-top:6px}.mt-2{margin-top:12px}.mt-3{margin-top:18px}.mt-4{margin-top:24px}
.p-3{padding:16px}.p-4{padding:22px}
.text-xs{font-size:11.5px}.text-sm{font-size:13px}.text-base{font-size:14px}.text-lg{font-size:16px}
.text-muted{color:var(--gray-400)}.text-primary{color:var(--primary)}.text-success{color:var(--success)}.text-danger{color:var(--danger)}
.fw-600{font-weight:600}.fw-700{font-weight:700}.fw-800{font-weight:800}
.text-center{text-align:center}.text-right{text-align:right}
.d-none{display:none}.w-full{width:100%}
.divider{border:none;border-top:1px solid var(--gray-200);margin:20px 0}
.empty-state{padding:48px 24px;text-align:center}
.empty-state .empty-icon{font-size:52px;margin-bottom:16px;opacity:.5}
.empty-state h4{color:var(--gray-700);margin-bottom:6px}
.empty-state p{color:var(--gray-400);font-size:13.5px}

@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes slideUp{from{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}
@keyframes spin{to{transform:rotate(360deg)}}
.spinner{width:22px;height:22px;border:2.5px solid var(--gray-200);border-top-color:var(--primary);border-radius:50%;animation:spin .7s linear infinite;display:inline-block}

@media print{.sidebar,.main-header,.btn,.header-actions,.page-header-actions{display:none !important}.main-content{margin:0;padding:20px}body{background:#fff}.card{box-shadow:none;border:1px solid #ddd}}

@media(max-width:768px){
  .sidebar{transform:translateX(-100%)}.sidebar.open{transform:translateX(0)}
  .main-header{left:0}.main-content{margin-left:0;padding:18px}
  #menu-btn{display:block !important}
  .stat-grid{grid-template-columns:1fr 1fr}
  .col-2,.col-3{grid-template-columns:1fr}
  .saas-nav{padding:14px 20px}.saas-nav-links{display:none}
  .saas-hero{padding:60px 20px 40px}.saas-hero h1{font-size:2rem}
  .saas-section{padding:40px 20px}
  .saas-footer{padding:40px 20px 20px}
  .saas-footer-grid{grid-template-columns:1fr 1fr}
  .login-box{padding:28px 22px}
}
@media(max-width:480px){
  .stat-grid{grid-template-columns:1fr}
  .page-header{flex-direction:column;align-items:flex-start}
}
