/* Lesbox manage portal — main stylesheet */
* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Arial, sans-serif; background: #f4f6f9; color: #222; }
a { color: #0066cc; text-decoration: none; }
a:hover { text-decoration: underline; }

.container { max-width: 1100px; margin: 0 auto; padding: 0 20px; }

/* Header */
.site-header { background: linear-gradient(135deg, #1a2a5e 0%, #2a4088 100%); color: #fff; padding: 12px 0; box-shadow: 0 2px 8px rgba(0,0,0,0.12); }
.header-row { display: flex; align-items: center; gap: 32px; }
.logo { color: #fff; font-size: 22px; font-weight: 700; letter-spacing: -0.5px; }
.logo:hover { text-decoration: none; opacity: 0.85; }
.main-nav { display: flex; gap: 4px; flex: 1; }
.main-nav a { color: rgba(255,255,255,0.85); padding: 8px 14px; border-radius: 6px; font-size: 14px; transition: background 0.15s; }
.main-nav a:hover { background: rgba(255,255,255,0.1); text-decoration: none; color: #fff; }
.main-nav a.active { background: rgba(255,255,255,0.18); color: #fff; font-weight: 600; }
.user-info { display: flex; align-items: center; gap: 10px; }
.user-name { color: rgba(255,255,255,0.9); font-size: 13px; max-width: 200px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

/* Main content */
.main-content { padding: 28px 20px 60px; min-height: calc(100vh - 180px); }
.main-content h1 { margin: 0 0 24px; font-size: 26px; color: #1a2a5e; }
.main-content h2 { margin: 28px 0 16px; font-size: 19px; color: #333; }

/* Guest (login/register) centered layout */
body.guest .main-content { display: flex; align-items: center; justify-content: center; min-height: calc(100vh - 100px); }
body.guest .auth-card { background: #fff; padding: 36px 40px; border-radius: 10px; box-shadow: 0 4px 20px rgba(0,0,0,0.08); max-width: 440px; width: 100%; }
body.guest .auth-card h1 { font-size: 22px; margin-top: 0; }

/* Forms */
.form-group { margin-bottom: 16px; }
.form-group label { display: block; margin-bottom: 5px; font-size: 13px; font-weight: 600; color: #444; }
.form-group input[type=text], .form-group input[type=email], .form-group input[type=password],
.form-group input[type=tel], .form-group textarea, .form-group select {
    width: 100%; padding: 9px 12px; border: 1px solid #d0d5db; border-radius: 6px; font-size: 14px;
    background: #fff; transition: border-color 0.15s, box-shadow 0.15s;
}
.form-group input:focus, .form-group textarea:focus, .form-group select:focus {
    outline: 0; border-color: #3b82f6; box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.18);
}
.form-group .help { font-size: 11px; color: #888; margin-top: 3px; }
.form-row { display: flex; gap: 14px; }
.form-row > .form-group { flex: 1; }
.form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.form-grid .full { grid-column: 1 / -1; }

/* Buttons */
.btn { display: inline-block; padding: 10px 20px; background: #3b82f6; color: #fff;
    border: 0; border-radius: 6px; font-size: 14px; font-weight: 500; cursor: pointer;
    transition: background 0.15s; text-decoration: none; }
.btn:hover { background: #2563eb; text-decoration: none; color: #fff; }
.btn-secondary { background: #6b7280; }
.btn-secondary:hover { background: #4b5563; }
.btn-green { background: #10b981; }
.btn-green:hover { background: #059669; }
.btn-red { background: #ef4444; }
.btn-red:hover { background: #dc2626; }
.btn-ghost { background: transparent; color: rgba(255,255,255,0.9); border: 1px solid rgba(255,255,255,0.3); }
.btn-ghost:hover { background: rgba(255,255,255,0.12); }
.btn.small { padding: 5px 12px; font-size: 12px; }
.btn.block { display: block; width: 100%; }

/* Card */
.card { background: #fff; border-radius: 10px; padding: 24px; box-shadow: 0 1px 4px rgba(0,0,0,0.05); margin-bottom: 20px; }
.card h2 { margin-top: 0; }

/* Table */
table { width: 100%; border-collapse: collapse; background: #fff; border-radius: 8px; overflow: hidden; box-shadow: 0 1px 4px rgba(0,0,0,0.05); }
th { background: #f3f4f6; padding: 10px 12px; text-align: left; font-size: 12px; font-weight: 600; color: #555; border-bottom: 1px solid #e5e7eb; }
td { padding: 12px; font-size: 13px; border-bottom: 1px solid #f3f4f6; }
tr:last-child td { border-bottom: 0; }
tr:hover td { background: #fafbfc; }

/* Badges */
.badge { display: inline-block; padding: 3px 10px; border-radius: 12px; font-size: 11px; font-weight: 600; color: #fff; }
.badge-active { background: #10b981; }
.badge-trial { background: #3b82f6; }
.badge-pending { background: #f59e0b; }
.badge-expired { background: #ef4444; }
.badge-suspended { background: #6b7280; }

/* Flash messages */
.flash { padding: 12px 18px; border-radius: 6px; margin-bottom: 16px; font-size: 14px; }
.flash-info { background: #dbeafe; color: #1e40af; border-left: 3px solid #3b82f6; }
.flash-success { background: #d1fae5; color: #065f46; border-left: 3px solid #10b981; }
.flash-error { background: #fee2e2; color: #991b1b; border-left: 3px solid #ef4444; }
.flash-warning { background: #fef3c7; color: #92400e; border-left: 3px solid #f59e0b; }

/* Stats grid (dashboard) */
.stats-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 16px; margin-bottom: 24px; }
.stat-card { background: #fff; padding: 20px; border-radius: 10px; box-shadow: 0 1px 4px rgba(0,0,0,0.05); }
.stat-card .label { font-size: 12px; color: #888; text-transform: uppercase; letter-spacing: 0.5px; margin-bottom: 6px; }
.stat-card .value { font-size: 24px; font-weight: 700; color: #1a2a5e; }
.stat-card .sub { font-size: 12px; color: #666; margin-top: 4px; }

/* Hero (register / login) */
.auth-card .sub-link { text-align: center; margin-top: 16px; font-size: 13px; color: #666; }
.auth-card .sub-link a { font-weight: 500; }

/* Detail list */
.detail-list { display: grid; grid-template-columns: 160px 1fr; gap: 8px 16px; font-size: 14px; }
.detail-list dt { color: #777; font-weight: 500; }
.detail-list dd { margin: 0; color: #222; }

/* Footer */
.site-footer { background: #fff; border-top: 1px solid #e5e7eb; padding: 16px 0; margin-top: 40px; font-size: 12px; color: #888; }
.site-footer .container { display: flex; justify-content: space-between; align-items: center; }
.footer-right a { color: #888; }

/* Responsive */
@media (max-width: 720px) {
    .header-row { flex-wrap: wrap; gap: 12px; }
    .main-nav { order: 3; flex-basis: 100%; overflow-x: auto; }
    .form-grid { grid-template-columns: 1fr; }
    .form-row { flex-direction: column; gap: 0; }
}
