/*
Theme Name: Sestavi Theme
Theme URI: https://sestavi.se
Author: Sestavi
Description: Custom lightweight WordPress theme without default WordPress visual style.
Version: 0.1.0
Text Domain: sestavi-theme
*/

:root {
  --sf-primary: #14b8a6;
  --sf-primary-dark: #0f766e;
  --sf-secondary: #22c55e;
  --sf-bg: #f8fafc;
  --sf-surface: #ffffff;
  --sf-text: #0f172a;
  --sf-muted: #64748b;
  --sf-border: #e2e8f0;
  --sf-radius: 18px;
  --sf-shadow: 0 18px 45px rgba(15, 23, 42, 0.08);
}

* { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
  margin: 0;
  font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  color: var(--sf-text);
  background: var(--sf-bg);
  line-height: 1.6;
}

a { color: inherit; text-decoration: none; }
a:hover { color: var(--sf-primary-dark); }
img { max-width: 100%; height: auto; display: block; }

.sf-container { width: min(1180px, calc(100% - 32px)); margin: 0 auto; }

.sf-header {
  position: sticky;
  top: 0;
  z-index: 100;
  background: rgba(255,255,255,0.92);
  border-bottom: 1px solid var(--sf-border);
  backdrop-filter: blur(16px);
}

.sf-header-inner {
  min-height: 76px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
}

.sf-logo { font-size: 1.35rem; font-weight: 800; letter-spacing: -0.03em; }
.sf-logo span { color: var(--sf-primary); }

.sf-nav ul { list-style: none; display: flex; gap: 22px; margin: 0; padding: 0; align-items: center; }
.sf-nav a { font-weight: 650; color: var(--sf-text); }

.sf-button, .wp-block-button__link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 12px 18px;
  border-radius: 999px;
  background: var(--sf-primary);
  color: #fff !important;
  font-weight: 750;
  border: 0;
  box-shadow: 0 10px 24px rgba(20,184,166,.24);
}

.sf-button.secondary { background: var(--sf-text); }

.sf-hero {
  padding: 72px 0 44px;
  background: radial-gradient(circle at top right, rgba(20,184,166,.18), transparent 36%), var(--sf-bg);
}

.sf-hero-grid { display: grid; grid-template-columns: 1.1fr .9fr; gap: 40px; align-items: center; }
.sf-eyebrow { color: var(--sf-primary-dark); font-weight: 800; text-transform: uppercase; font-size: .82rem; letter-spacing: .08em; }
.sf-hero h1 { font-size: clamp(2.4rem, 5vw, 4.8rem); line-height: 1.02; letter-spacing: -0.06em; margin: 10px 0 18px; }
.sf-hero p { font-size: 1.15rem; color: var(--sf-muted); max-width: 650px; }

.sf-panel {
  background: var(--sf-surface);
  border: 1px solid var(--sf-border);
  border-radius: var(--sf-radius);
  box-shadow: var(--sf-shadow);
  padding: 28px;
}

.sf-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 22px; margin: 36px 0; }
.sf-card {
  background: var(--sf-surface);
  border: 1px solid var(--sf-border);
  border-radius: var(--sf-radius);
  overflow: hidden;
  box-shadow: 0 10px 30px rgba(15, 23, 42, 0.05);
}
.sf-card-content { padding: 22px; }
.sf-card h2, .sf-card h3 { margin: 0 0 10px; line-height: 1.2; }
.sf-card p { color: var(--sf-muted); margin: 0; }

.sf-main { padding: 42px 0 72px; }
.sf-content {
  background: var(--sf-surface);
  border: 1px solid var(--sf-border);
  border-radius: var(--sf-radius);
  box-shadow: var(--sf-shadow);
  padding: min(7vw, 52px);
}
.sf-content h1 { font-size: clamp(2rem, 4vw, 3.6rem); line-height: 1.06; letter-spacing: -0.04em; }
.sf-content p, .sf-content li { font-size: 1.05rem; }

.sf-dashboard { display: grid; grid-template-columns: 260px 1fr; gap: 24px; }
.sf-sidebar, .sf-dashboard-main { background: var(--sf-surface); border: 1px solid var(--sf-border); border-radius: var(--sf-radius); padding: 22px; }
.sf-sidebar ul { list-style:none; padding:0; margin:0; display:grid; gap:10px; }
.sf-sidebar a { display:block; padding:10px 12px; border-radius:12px; background:#f1f5f9; font-weight:700; }

.sf-footer { padding: 44px 0; background: #0f172a; color: #e2e8f0; }
.sf-footer a { color: #fff; }
.sf-footer-grid { display: grid; grid-template-columns: 1.4fr repeat(3, 1fr); gap: 28px; }
.sf-footer h3 { color: #fff; margin-top: 0; }
.sf-footer ul { list-style:none; padding:0; margin:0; display:grid; gap:8px; }

@media (max-width: 860px) {
  .sf-hero-grid, .sf-dashboard, .sf-footer-grid { grid-template-columns: 1fr; }
  .sf-grid { grid-template-columns: 1fr; }
  .sf-nav { display:none; }
}
