/*
Theme Name: Legisite
Theme URI: https://legisite.com
Author: Legisite
Author URI: https://legisite.com
Description: A clean, modern and professional theme for Legisite with Swedish copy preloaded and sections tailored for accessibility services.
Version: 1.0.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: legisite
*/

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

:root{
  --bg:#0b0c10;
  --surface:#ffffff;
  --muted:#f4f5f7;
  --text:#0f172a;
  --text-invert:#ffffff;
  --primary:#2b72ff;
  --primary-600:#1f5de0;
  --accent:#00c2a8;
  --border:#e5e7eb;
  --shadow:0 10px 30px rgba(15,23,42,0.08);
  --radius:16px;
}

html,body{
  margin:0;
  padding:0;
  font-family:Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  color:var(--text);
  background:#ffffff;
  line-height:1.6;
}

.container{
  width: min(1200px, 92%);
  margin: 0 auto;
}

.header{
  position:sticky; top:0; z-index:50;
  background:#ffffff;
  border-bottom:1px solid var(--border);
  backdrop-filter:saturate(180%) blur(6px);
}

.header-inner{ display:flex; align-items:center; justify-content:space-between; padding:16px 0; }
.brand{ display:flex; align-items:center; gap:12px; text-decoration:none; color:var(--text); }
.brand .name{ font-weight:700; font-size:20px; letter-spacing:0.2px; }

.nav{ display:flex; gap:22px; align-items:center; }
.nav a{ text-decoration:none; color:#0f172a; font-weight:500; }
.nav a:hover{ color:var(--primary); }

.btn{
  display:inline-block; padding:12px 18px; border-radius:12px; text-decoration:none; font-weight:600;
  box-shadow:var(--shadow);
}
.btn-primary{ background:var(--primary); color:var(--text-invert); }
.btn-primary:hover{ background:var(--primary-600); }
.btn-outline{ border:1px solid var(--border); color:var(--text); background:#fff; }
.btn-outline:hover{ border-color:var(--primary); color:var(--primary); }

.hero{
  padding: 72px 0 40px;
  background: radial-gradient(1200px 600px at 70% -20%, rgba(43,114,255,0.08), transparent), #ffffff;
}
.hero h1{ font-size: clamp(28px, 4vw, 48px); line-height:1.15; margin:0 0 12px; }
.hero p{ font-size: clamp(16px, 2.2vw, 20px); color:#334155; margin:0 0 24px; }
.hero .cta{ display:flex; gap:14px; flex-wrap:wrap; }

.section{ padding: 56px 0; }
.section.alt{ background: var(--muted); }

/* Centrera rubriken i denna sektion */
.section.alt .container > h2{
  text-align: center;
  margin: 0 0 24px;
}

.grid-3{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 22px;
}
@media(max-width:900px){
  .grid-3{ grid-template-columns: 1fr; }
}

/* Centrera innehållet i korten */
.card{
  background:#fff;
  border:1px solid var(--border);
  border-radius: var(--radius);
  padding:22px;
  box-shadow: var(--shadow);
  text-align: center;
}

/* Små finjusteringar för typografi i korten */
.card h3{ margin: 0 0 8px; }
.card p{ margin: 0; }


.pricing{
  display:grid; grid-template-columns:repeat(4,1fr); gap:22px;
}
@media(max-width:1100px){ .pricing{ grid-template-columns:1fr 1fr; } }
@media(max-width:720px){ .pricing{ grid-template-columns:1fr; } }

.price-card .price{ font-size:24px; font-weight:700; margin:10px 0 12px; }
.price-card ul{ padding-left:18px; margin:12px 0; }
.price-card li{ margin:6px 0; }

.footer{
  padding:28px 0;
  background:#0f172a; color:#cbd5e1;
  margin-top:40px;
}
.footer a{ color:#e2e8f0; text-decoration:none; }
.footer a:hover{ color:#ffffff; }

.notice-red {
    background-color: #fee2e2; /* Ljus röd bakgrund */
    color: #991b1b; /* Mörk röd text */
    padding: 12px 16px;
    border-radius: 8px;
    border: 1px solid #fecaca; /* Ljusare röd kant */
    font-size: 0.95rem;
    margin-top: 12px; /* Lite luft ovanför */
    display: inline-block; /* Så att bredden följer innehållet */
}

.law-alert {
    font-weight: 700; /* Tjockare text */
    color: #b91c1c; /* Ännu mörkare röd för kontrast */
}


.mobile-nav-toggle{ display:none; background:#fff; border:1px solid var(--border); border-radius:10px; padding:10px 12px; }
@media(max-width:900px){
  .nav{ display:none; }
  .mobile-nav-toggle{ display:inline-block; }
  .nav.open{ display:flex; flex-direction:column; gap:12px; position:absolute; left:0; right:0; top:64px; background:#fff; padding:16px; border-bottom:1px solid var(--border); }
}
/* Pricing Layout */
.pricing-hero {
  max-width: 860px;
  margin: 0 auto 28px;
  color: #475569;
  text-align: center;
}

.pricing-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 26px;
  margin-top: 18px;
}

.pricing-card {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

.pricing-card .pricing-cta {
  margin-top: auto; /* Trycker knappen till botten */
}


.pricing-card {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 18px;
  padding: 26px;
  box-shadow: 0 14px 38px rgba(15,23,42,.08);
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}

.pricing-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 18px 46px rgba(15,23,42,.12);
  border-color: #dbeafe;
}

.pricing-badge {
  display: inline-block;
  background: #eef2ff;
  color: #1f5de0;
  border: 1px solid #c7d2fe;
  padding: 6px 10px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .3px;
}

.pricing-title { font-size: 22px; font-weight: 800; margin: 12px 0 6px; }
.pricing-price { font-size: 28px; font-weight: 800; margin: 6px 0 12px; }
.pricing-desc { color: #475569; margin: 0 0 14px; }

.pricing-features { margin: 0 0 14px; padding-left: 18px; }
.pricing-features li { margin: 6px 0; }

.pricing-cta { margin-top: 12px; }
.pricing-note { font-size: 13px; color: #64748b; margin-top: 10px; }

.section-split { margin-top: 44px; border-top: 1px solid var(--border); padding-top: 30px; }

.plan-side {
  background: var(--muted);
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 18px;
  margin-top: 18px;
  color: #334155;
}

.btn-primary {
  display: inline-flex; /* Gör att texten centreras både horisontellt och vertikalt */
  align-items: center;
  justify-content: center;
  padding: 14px 28px; /* Mer luft runt texten */
  background: #1f5de0; /* Samma blå */
  color: #fff;
  text-decoration: none;
  border-radius: 8px; /* Lite mjukare hörn */
  font-weight: 700; /* Tjockare text */
  font-size: 1.1rem; /* Lite större text */
  border: none;
  cursor: pointer;
  transition: background-color 0.25s ease, transform 0.15s ease;
}

.btn-primary:hover {
  background: #1744a3; /* Mörkare blå vid hover */
  transform: translateY(-2px); /* Liten lyft-animation */
}

.btn-primary:active {
  transform: translateY(0); /* Tar bort lyftet vid klick */
}

.btn-secondary:hover { background: #475569; }

@keyframes pulseHighlight {
  0%   { box-shadow: 0 0 0 rgba(43,114,255,0); }
  50%  { box-shadow: 0 0 28px rgba(43,114,255,0.55); }
  100% { box-shadow: 0 0 0 rgba(43,114,255,0); }
}

.highlight {
  animation: pulseHighlight 1.2s ease;
  animation-iteration-count: 2;
}

/* Respekt för användare som föredrar mindre rörelse */
@media (prefers-reduced-motion: reduce) {
  .highlight { animation: none; }
  html { scroll-behavior: auto; }
}

.plan-side.platinum {
  background: linear-gradient(135deg, #e5e4e2, #cfd8dc); /* Platinum med lätt blå ton */
  border: 1px solid #b0bec5;
  box-shadow: 0 4px 12px rgba(31, 93, 224, 0.15); /* Lätt blå skugga */
}
/* Om oss – diskret layoutfinputs */
.about-hero-inner{
  display:grid; grid-template-columns:1.2fr .8fr; gap:28px; align-items:center;
}
@media(max-width:900px){ .about-hero-inner{ grid-template-columns:1fr; } }

.founder-card{
  background:#fff; border:1px solid var(--border); border-radius:16px; padding:18px;
  box-shadow: var(--shadow); display:grid; grid-template-columns:96px 1fr; gap:16px; align-items:center;
}
.founder-photo{
  width:96px; height:96px; border-radius:50%; object-fit:cover; border:2px solid #e2e8f0;
}
.founder-facts{ margin:10px 0 0; padding-left:18px; }
.founder-facts li{ margin:6px 0; }

.about-steps{ margin:10px 0 0 18px; }
.about-steps li{ margin:8px 0; }

.about-cta{ background:var(--muted); }
.about-cta-inner{
  display:flex; gap:18px; align-items:center; justify-content:space-between;
  border:1px solid var(--border); border-radius:16px; padding:20px; background:#fff;
}
.about-cta-actions{ display:flex; gap:12px; flex-wrap:wrap; }

/* Kontakt */
.contact-hero p{ color:#475569; max-width:720px; }
.contact-meta{ margin:10px 0 0; padding-left:18px; }
.contact-meta li{ margin:6px 0; }
.contact-note{ color:#64748b; margin-top:10px; }
.contact-form-card h3{ margin-top:0; }

/* Rekommenderas-band */
.recommended {
  position: relative;
}
.recommended-badge{
  position:absolute; top:12px; right:12px;
  background:#1f5de0; color:#fff; font-weight:700;
  padding:6px 10px; border-radius:999px; font-size:12px;
  box-shadow: var(--shadow);
}
/* Små listpriser för avtalslängd – redan i din stil via .pricing-features */

/* Centrera text i priskort */
.pricing-card {
  text-align: center;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

/* Punkterna vänsterjusterade men centrerat block */
.pricing-card ul {
  text-align: left;
  display: inline-block;
  margin: 0 auto;
}

/* Jämna knappar längst ner */
.pricing-cta {
  margin-top: auto;
}

.pricing-card { display:flex; flex-direction:column; text-align:center; }
.pricing-card .pricing-desc { margin: 8px 0 10px; color:#475569; }
.pricing-card ul { text-align:left; display:inline-block; margin: 0 auto 10px; }
.pricing-card .pricing-cta { margin-top:auto; }

/* Billing switcher */
.billing-switcher{
  display:flex; gap:10px; align-items:center; flex-wrap:wrap; margin:10px 0 8px;
}
.billing-btn{
  border:1px solid var(--border);
  background:#fff;
  padding:8px 12px; border-radius:999px;
  font-weight:600; cursor:pointer;
}
.billing-btn.is-active{ 
  background:#1f5de0; color:#fff; border-color:#1f5de0;
}
.billing-note{ color:#475569; margin:0 0 14px; }

/* Prisrad + total */
.billing-price{ margin:10px 0 8px; }
.price-line{
  display:flex; align-items:baseline; justify-content:center; gap:12px;
}
.pricing-price{ font-size:22px; font-weight:800; }
.total-line{ color:#64748b; font-weight:600; }

/* Små värdechips */
.value-points{ display:flex; gap:8px; justify-content:center; flex-wrap:wrap; margin:10px 0; }
.value-chip{
  background:#eef2ff; color:#1f5de0; border:1px solid #c7d2fe;
  padding:4px 10px; border-radius:999px; font-size:12px; font-weight:700;
}

/* Se till att knapparna hamnar i botten och listan är vänster men centrerad blockbredd */
.plan-card{ display:flex; flex-direction:column; text-align:center; }
.plan-card ul{ text-align:left; display:inline-block; margin:0 auto 10px; }
.plan-card .pricing-cta{ margin-top:auto; }

/* Kontaktknappar – frikopplade från tema */
.contact-btn{all:unset;display:inline-block;padding:12px 16px;border-radius:10px;
  font-size:16px;line-height:1.1;font-weight:800;text-decoration:none;white-space:nowrap;cursor:pointer}
.contact-btn--primary{background:#0056b3;color:#fff;border:1px solid #0056b3;box-shadow:0 6px 18px rgba(0,0,0,.08)}
.contact-btn--secondary{background:#fff;color:#0f172a;border:1px solid #d1d5db}
.contact-btn::before,.contact-btn::after{content:none !important;display:none !important;}
