/* Grandevu Hantverkare — Premium dark theme, mobile-first */
*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }

:root {
  --dark: #0d0d1a;
  --dark2: #1a1a2e;
  --dark3: #16213e;
  --gold: #c4a35a;
  --gold-light: #e8d5a3;
  --white: #f0ece2;
  --grey: #999;
  --green: #2ecc71;
  --red: #e74c3c;
  --blue: #3498db;
  --orange: #f39c12;
  --serif: Georgia, Garamond, serif;
  --sans: 'Helvetica Neue', Arial, sans-serif;
  --radius: 8px;
}

html { font-size: 15px; }
body { font-family: var(--sans); background: var(--dark); color: var(--white); min-height: 100vh; }
a { color: var(--gold); text-decoration: none; }
a:hover { opacity: 0.8; }

/* === PUBLIC SITE === */
.pub-nav { padding: 20px 30px; display: flex; justify-content: space-between; align-items: center; border-bottom: 1px solid rgba(196,163,90,0.1); }
.pub-logo { font-family: var(--serif); font-size: 1.3rem; }
.pub-logo span { color: var(--gold); }
.pub-nav-links { display: flex; gap: 24px; list-style: none; }
.pub-nav-links a { color: var(--grey); font-size: 0.85rem; letter-spacing: 1px; text-transform: uppercase; }
.pub-nav-links a:hover { color: var(--gold); }

.pub-hero { min-height: 70vh; display: flex; flex-direction: column; justify-content: center; align-items: center; text-align: center; padding: 60px 24px; }
.pub-hero h1 { font-family: var(--serif); font-size: clamp(2rem, 6vw, 4rem); margin-bottom: 20px; }
.pub-hero h1 em { color: var(--gold); font-style: italic; }
.pub-hero p { color: var(--grey); max-width: 500px; line-height: 1.8; margin-bottom: 30px; }

.pub-cta { display: inline-block; padding: 14px 36px; border: 1px solid var(--gold); color: var(--gold); font-size: 0.85rem; letter-spacing: 2px; text-transform: uppercase; transition: all 0.3s; }
.pub-cta:hover { background: var(--gold); color: var(--dark); opacity: 1; }

.pub-section { padding: 80px 30px; max-width: 800px; margin: 0 auto; }
.pub-section h2 { font-family: var(--serif); font-size: 1.8rem; margin-bottom: 20px; }

.pub-footer { padding: 40px 30px; border-top: 1px solid rgba(196,163,90,0.1); text-align: center; color: var(--grey); font-size: 0.8rem; }

/* === FORMS === */
.form-group { margin-bottom: 16px; }
.form-group label { display: block; font-size: 0.8rem; color: var(--gold); letter-spacing: 1px; text-transform: uppercase; margin-bottom: 6px; }
.form-group input, .form-group textarea, .form-group select {
  width: 100%; padding: 12px 16px; background: rgba(255,255,255,0.05);
  border: 1px solid rgba(196,163,90,0.2); color: var(--white);
  font-family: var(--sans); font-size: 0.95rem; border-radius: var(--radius);
}
.form-group input:focus, .form-group textarea:focus, .form-group select:focus { outline: none; border-color: var(--gold); }
.form-group select option { background: #1a1a2e; color: #f0ece2; }
.form-group select { color: var(--white); }
.form-group input::placeholder, .form-group textarea::placeholder { color: #666; }
.form-group textarea { min-height: 120px; resize: vertical; }

/* === BUTTONS === */
.btn { display: inline-block; padding: 12px 28px; border: 1px solid var(--gold); color: var(--gold); font-size: 0.8rem; letter-spacing: 1px; text-transform: uppercase; cursor: pointer; background: none; font-family: var(--sans); border-radius: var(--radius); transition: all 0.3s; }
.btn:hover { background: var(--gold); color: var(--dark); opacity: 1; }
.btn-solid { background: var(--gold); color: var(--dark); }
.btn-sm { padding: 8px 16px; font-size: 0.7rem; }
.btn-danger { border-color: var(--red); color: var(--red); }
.btn-danger:hover { background: var(--red); color: white; }

/* === ADMIN LAYOUT === */
.admin-header { padding: 16px 24px; background: var(--dark2); border-bottom: 1px solid rgba(196,163,90,0.1); display: flex; justify-content: space-between; align-items: center; position: sticky; top: 0; z-index: 50; }
.admin-header h1 { font-family: var(--serif); font-size: 1.3rem; }
.admin-header .logo { font-family: var(--serif); font-size: 1.2rem; }
.admin-header .logo span { color: var(--gold); }

.admin-nav { display: flex; gap: 4px; padding: 8px 16px; background: var(--dark2); border-bottom: 1px solid rgba(196,163,90,0.1); overflow-x: auto; }
.admin-nav a { padding: 10px 20px; color: var(--grey); font-size: 1rem; font-weight: 600; border-radius: 6px; white-space: nowrap; }
.admin-nav a:hover { background: rgba(196,163,90,0.05); color: var(--white); opacity: 1; }
.admin-nav a.active { background: rgba(196,163,90,0.1); color: var(--gold); }

.admin-content { padding: 24px; max-width: 1200px; margin: 0 auto; }

/* === DASHBOARD STATS === */
.stats { display: grid; grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)); gap: 16px; margin-bottom: 24px; }
.stat { background: var(--dark2); border: 1px solid rgba(196,163,90,0.1); border-radius: var(--radius); padding: 20px; }
.stat:hover { border-color: var(--gold); }
.stat-label { font-size: 0.7rem; color: var(--grey); letter-spacing: 1px; text-transform: uppercase; margin-bottom: 6px; }
.stat-value { font-family: var(--serif); font-size: 1.6rem; color: var(--gold); }
.stat-sub { font-size: 0.75rem; color: var(--grey); margin-top: 4px; }
.stat-positive { color: var(--green); }
.stat-negative { color: var(--red); }
.stat-warning { color: var(--orange); }

/* === SKATTETIPS === */
.tip-card { background: linear-gradient(135deg, var(--dark3), var(--dark2)); border: 1px solid rgba(196,163,90,0.2); border-radius: var(--radius); padding: 20px; margin-bottom: 16px; }
.tip-card .tip-icon { color: var(--gold); font-size: 1.2rem; margin-bottom: 8px; }
.tip-card .tip-title { font-weight: bold; margin-bottom: 6px; }
.tip-card .tip-text { font-size: 0.9rem; color: var(--grey); line-height: 1.6; }

/* === TABLES === */
.table-wrap { background: var(--dark2); border: 1px solid rgba(196,163,90,0.1); border-radius: var(--radius); overflow: hidden; margin-bottom: 24px; }
.table-title { padding: 16px 20px; font-family: var(--serif); border-bottom: 1px solid rgba(196,163,90,0.1); display: flex; justify-content: space-between; align-items: center; }
table { width: 100%; border-collapse: collapse; }
thead th { padding: 10px 16px; text-align: left; font-size: 0.7rem; letter-spacing: 1px; text-transform: uppercase; color: var(--gold); border-bottom: 1px solid rgba(196,163,90,0.1); }
tbody td { padding: 12px 16px; font-size: 0.9rem; border-bottom: 1px solid rgba(255,255,255,0.03); }
tbody tr:hover { background: rgba(196,163,90,0.03); }

.badge { display: inline-block; padding: 3px 10px; border-radius: 20px; font-size: 0.7rem; letter-spacing: 0.5px; text-transform: uppercase; font-weight: 600; }
.badge-ny { background: rgba(52,152,219,0.15); color: var(--blue); }
.badge-utkast { background: rgba(153,153,153,0.15); color: var(--grey); }
.badge-skickad { background: rgba(196,163,90,0.15); color: var(--gold); }
.badge-godkand { background: rgba(46,204,113,0.15); color: var(--green); }
.badge-fakturerad { background: rgba(155,89,182,0.15); color: #9b59b6; }
.badge-obetalad { background: rgba(243,156,18,0.15); color: var(--orange); }
.badge-betald { background: rgba(46,204,113,0.15); color: var(--green); }
.badge-avvisad { background: rgba(231,76,60,0.15); color: var(--red); }

/* === CARDS === */
.card { background: var(--dark2); border: 1px solid rgba(196,163,90,0.1); border-radius: var(--radius); padding: 24px; margin-bottom: 16px; }
.card h3 { font-family: var(--serif); font-weight: 400; margin-bottom: 16px; padding-bottom: 10px; border-bottom: 1px solid rgba(196,163,90,0.1); }

/* === FLASH === */
.flash { padding: 12px 20px; margin-bottom: 16px; border-radius: var(--radius); font-size: 0.9rem; }
.flash.error { background: rgba(231,76,60,0.1); border: 1px solid var(--red); color: var(--red); }
.flash.success { background: rgba(46,204,113,0.1); border: 1px solid var(--green); color: var(--green); }

/* === KUNDPORTAL (ljusare) === */
.kund-body { background: #f8f6f1; color: #333; }
.kund-header { background: white; padding: 16px 24px; border-bottom: 1px solid #e0d0bc; display: flex; justify-content: space-between; align-items: center; }
.kund-content { padding: 24px; max-width: 900px; margin: 0 auto; }
.kund-card { background: white; border: 1px solid #e0d0bc; border-radius: var(--radius); padding: 24px; margin-bottom: 16px; }
.kund-card h3 { color: #333; font-family: var(--serif); margin-bottom: 12px; }
.kund-stat { background: white; border: 1px solid #e0d0bc; border-radius: var(--radius); padding: 20px; text-align: center; }
.kund-stat .value { font-family: var(--serif); font-size: 1.4rem; color: var(--gold); }
.kund-stat .label { font-size: 0.75rem; color: #999; margin-top: 4px; }

/* === LOGIN (centrerad) === */
.login-page { min-height: 100vh; display: flex; justify-content: center; align-items: center; }
.login-box { width: 380px; padding: 50px 40px; background: var(--dark2); border: 1px solid rgba(196,163,90,0.15); border-radius: var(--radius); text-align: center; }
.login-box h1 { font-family: var(--serif); font-size: 1.5rem; margin-bottom: 6px; }
.login-box .sub { color: var(--gold); font-size: 0.85rem; margin-bottom: 24px; }

/* === MOMSPERIODER === */
.moms-kvartaler { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 16px; }
.moms-kvartal { background: var(--dark); border: 1px solid rgba(255,255,255,0.05); border-radius: var(--radius); padding: 16px; }
.moms-kvartal.moms-betald { border-color: rgba(46,204,113,0.2); }
.moms-kvartal.moms-obetald { border-color: rgba(243,156,18,0.3); }
.moms-kvartal-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 12px; }
.moms-period-text { color: var(--grey); font-size: 0.8rem; margin-left: 8px; }
.moms-kvartal-rader { font-size: 0.85rem; }
.moms-rad { display: flex; justify-content: space-between; padding: 4px 0; }
.moms-rad.moms-total { padding-top: 8px; margin-top: 4px; border-top: 1px solid rgba(255,255,255,0.05); font-weight: bold; }
.moms-deadline { font-size: 0.75rem; color: var(--orange); margin-top: 8px; text-align: center; }

/* === RESPONSIVE === */
@media (max-width: 600px) {
  .stats { grid-template-columns: repeat(2, 1fr); }
  .admin-content { padding: 16px; }
  .pub-hero { min-height: 50vh; }
  .admin-nav { gap: 2px; padding: 6px 8px; }
  .admin-nav a { padding: 8px 14px; font-size: 0.9rem; }
}
