/*
Theme Name: Potilas.com Modern
Theme URI: https://potilas.com/
Author: Mediatomaatti / Potilas.com
Description: Premium, accessible and SEO/GEO-ready WordPress theme skeleton for Potilas.com: contact directory, patient guides, decision tools and service place templates.
Version: 1.3.1
Requires at least: 6.2
Tested up to: 6.7
Requires PHP: 8.0
Text Domain: potilascom
License: GPL-2.0-or-later
*/

:root {
  --potilas-blue: #1E5B8C;
  --potilas-blue-dark: #143E61;
  --potilas-blue-ink: #092238;
  --potilas-mint: #DDF3EA;
  --potilas-mint-soft: #F2FAF7;
  --potilas-coral: #E66B5B;
  --potilas-ink: #102033;
  --potilas-muted: #5D6B7A;
  --potilas-line: #DDE5ED;
  --potilas-bg: #F7FAFC;
  --potilas-white: #FFFFFF;
  --radius-sm: 10px;
  --radius-md: 16px;
  --radius-lg: 24px;
  --radius-xl: 34px;
  --shadow-sm: 0 8px 24px rgba(16, 32, 51, .06);
  --shadow-md: 0 18px 50px rgba(16, 32, 51, .11);
  --container: 1180px;
  --font-ui: "Manrope", "Nunito Sans", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
  margin: 0;
  font-family: var(--font-ui);
  color: var(--potilas-ink);
  background: var(--potilas-bg);
  line-height: 1.65;
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
}
img { max-width: 100%; height: auto; }
a { color: var(--potilas-blue); text-decoration-thickness: .08em; text-underline-offset: .18em; }
a:hover { color: var(--potilas-blue-dark); }
:focus-visible { outline: 3px solid var(--potilas-coral); outline-offset: 3px; border-radius: 6px; }
.screen-reader-text { position:absolute !important; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0; }

.skip-link {
  position: absolute; left: -999px; top: 12px; z-index: 9999;
  background: var(--potilas-blue); color: #fff; padding: 10px 14px; border-radius: 8px;
}
.skip-link:focus { left: 12px; }

.container { width: min(100% - 32px, var(--container)); margin-inline: auto; }
.site-header {
  position: sticky; top: 0; z-index: 50; background: rgba(255,255,255,.92);
  backdrop-filter: saturate(180%) blur(14px); border-bottom: 1px solid var(--potilas-line);
}
.header-inner { min-height: 76px; display: flex; align-items: center; justify-content: space-between; gap: 24px; }
.brand { display:flex; align-items:center; gap:12px; font-weight: 900; font-size: 1.35rem; text-decoration:none; color: var(--potilas-blue); white-space: nowrap; }
.brand-mark { width:42px; height:42px; border-radius: 14px; display:grid; place-items:center; background: var(--potilas-mint); color: var(--potilas-blue); font-weight: 900; box-shadow: inset 0 -1px 0 rgba(30,91,140,.08); }
.brand-logo img, .custom-logo { display:block; max-height: 48px; width: auto; }
.site-nav { display:flex; align-items:center; gap:18px; }
.site-nav ul { list-style:none; display:flex; align-items:center; gap: 16px; margin:0; padding:0; }
.site-nav a { color: var(--potilas-ink); text-decoration:none; font-weight:650; font-size:.94rem; }
.site-nav a:hover, .site-nav .current-menu-item > a { color: var(--potilas-blue); }
.header-cta { margin-left: 2px; }
.mobile-menu-toggle { display:none; align-items:center; gap:8px; border:1px solid var(--potilas-line); background:#fff; border-radius: 999px; padding:10px 13px; font-weight:850; color: var(--potilas-ink); }
.mobile-menu-lines, .mobile-menu-lines::before, .mobile-menu-lines::after { display:block; width:16px; height:2px; border-radius:2px; background: var(--potilas-blue); content:""; }
.mobile-menu-lines { position:relative; }
.mobile-menu-lines::before { position:absolute; top:-5px; }
.mobile-menu-lines::after { position:absolute; top:5px; }

.button, .wp-block-button__link, button, input[type="submit"] {
  display:inline-flex; align-items:center; justify-content:center; gap:.5rem;
  min-height: 42px; padding: 10px 18px; border-radius: 999px; border: 0;
  background: var(--potilas-blue); color:#fff; text-decoration:none; font-weight: 820; cursor:pointer;
  box-shadow: 0 8px 20px rgba(30, 91, 140, .16);
  transition: transform .18s ease, box-shadow .18s ease, background .18s ease, border-color .18s ease;
}
.button:hover, .wp-block-button__link:hover, button:hover, input[type="submit"]:hover { background: var(--potilas-blue-dark); color:#fff; transform: translateY(-1px); box-shadow: 0 12px 26px rgba(30, 91, 140, .20); }
.button.secondary { background: var(--potilas-mint); color: var(--potilas-blue-dark); box-shadow: none; }
.button.secondary:hover { background: #cceee2; color: var(--potilas-blue-dark); }
.button.ghost { background:#fff; color: var(--potilas-blue); border:1px solid var(--potilas-line); box-shadow: none; }
.button.ghost:hover { border-color: rgba(30,91,140,.35); color: var(--potilas-blue-dark); background: #fff; }
.button.coral { background: var(--potilas-coral); }

.hero {
  padding: clamp(42px, 6vw, 86px) 0 clamp(36px, 5vw, 64px);
  background:
    radial-gradient(circle at 88% 6%, rgba(221,243,234,.95), transparent 35%),
    radial-gradient(circle at 12% 94%, rgba(30,91,140,.08), transparent 38%),
    linear-gradient(135deg, #fff 0%, #F4FAFD 100%);
  border-bottom: 1px solid var(--potilas-line);
  overflow: hidden;
}
.hero-grid { display:grid; grid-template-columns: minmax(0,1.04fr) minmax(380px,.96fr); gap: clamp(30px, 5vw, 78px); align-items:center; }
.hero-copy { position: relative; z-index: 1; }
.hero-copy::before { content:""; position:absolute; width: 154px; height: 154px; border: 22px solid rgba(221,243,234,.42); border-radius: 50%; left: -70px; top: -34px; z-index: -1; }
.eyebrow { color: var(--potilas-blue); font-weight: 900; letter-spacing:.08em; text-transform: uppercase; font-size:.78rem; margin: 0 0 14px; }
h1, h2, h3 { line-height:1.13; margin: 0 0 .65em; letter-spacing: -.032em; }
h1 { font-size: clamp(2.45rem, 5.55vw, 4.75rem); max-width: 920px; color: var(--potilas-blue-ink); }
h2 { font-size: clamp(1.7rem, 3vw, 2.55rem); color: var(--potilas-blue-ink); }
h3 { font-size: clamp(1.14rem, 1.8vw, 1.42rem); }
.lead { font-size: clamp(1.03rem, 1.45vw, 1.17rem); color: var(--potilas-muted); max-width: 720px; line-height: 1.8; }
.hero-card, .card, .article-card, .feature-card, .decision-card {
  background:#fff; border:1px solid var(--potilas-line); border-radius: var(--radius-lg); box-shadow: var(--shadow-sm); padding: clamp(20px, 3vw, 32px);
}
.hero-card { border-radius: var(--radius-xl); box-shadow: 0 18px 46px rgba(16,32,51,.08); }
.situation-panel { position: relative; }
.situation-panel::after { content:""; position:absolute; inset:auto 26px 18px auto; width:74px; height:10px; border-radius:999px; background: var(--potilas-coral); opacity:.18; }

.search-box { display:flex; gap:10px; background:#fff; padding: 8px; border:1px solid var(--potilas-line); border-radius: 999px; box-shadow: var(--shadow-sm); max-width: 780px; margin: 28px 0 18px; }
.search-box:focus-within { border-color: rgba(30,91,140,.42); box-shadow: 0 12px 34px rgba(30,91,140,.11); }
.search-box input { flex:1; border:0; min-height:48px; padding: 0 18px; font-size:1rem; outline: none; background:transparent; min-width: 0; }
.search-box button { min-width: 96px; }
.hero-actions { display:flex; flex-wrap: wrap; gap:10px; margin-top: 10px; }
.hero-note { display:flex; gap:10px; align-items:flex-start; color: var(--potilas-muted); font-size: .96rem; margin: 18px 0 0; max-width: 680px; }
.hero-note span { width:6px; height:24px; background: var(--potilas-coral); border-radius:999px; flex:0 0 auto; margin-top:3px; }
.quick-grid { display:grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap:12px; }
.quick-card { display:flex; align-items:flex-start; gap:12px; padding:16px; border:1px solid var(--potilas-line); border-radius: var(--radius-md); background: #fff; color: var(--potilas-ink); text-decoration:none; font-weight:650; min-height: 88px; transition: transform .16s ease, border-color .16s ease, box-shadow .16s ease, background .16s ease; }
.quick-card:hover { border-color: rgba(30,91,140,.45); box-shadow: var(--shadow-sm); color: var(--potilas-blue); transform: translateY(-2px); background: linear-gradient(180deg, #fff, #FAFDFB); }
.quick-card strong { display:block; line-height:1.35; color: var(--potilas-blue-ink); }
.quick-card small { display:block; color: var(--potilas-muted); font-weight:500; line-height:1.45; margin-top: 5px; }
.quick-icon, .feature-icon { width:38px; height:38px; border-radius: 14px; background: var(--potilas-mint); display:grid; place-items:center; color: var(--potilas-blue); flex: 0 0 auto; }
.quick-icon svg, .feature-icon svg { width:20px; height:20px; fill:none; stroke: currentColor; stroke-width: 2.3; stroke-linecap: round; stroke-linejoin: round; }

.trust-strip { background: rgba(255,255,255,.86); border-bottom: 1px solid var(--potilas-line); }
.trust-strip-inner { display:flex; flex-wrap:wrap; gap: 10px 26px; align-items:center; padding-block: 14px; }
.trust-strip p { display:flex; align-items:center; gap:9px; margin:0; color: var(--potilas-muted); font-size:.94rem; }
.trust-strip p span { width:24px; height:24px; border-radius:999px; display:inline-grid; place-items:center; background: var(--potilas-mint); color: var(--potilas-blue); font-weight:900; flex:0 0 auto; }

.section { padding: clamp(44px, 6vw, 84px) 0; }
.section-soft { background: linear-gradient(180deg, var(--potilas-mint-soft), #fff); border-block: 1px solid var(--potilas-line); }
.section-title { display:flex; justify-content:space-between; align-items:end; gap:24px; margin-bottom:24px; }
.grid-3 { display:grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap:18px; }
.grid-2 { display:grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap:18px; }
.card { color: inherit; }
a.card, .feature-card { text-decoration: none; display:block; }
a.card:hover, .feature-card:hover { transform: translateY(-2px); box-shadow: var(--shadow-md); border-color: rgba(30,91,140,.25); }
.card p:last-child, .feature-card p:last-child, .decision-card p:last-child { margin-bottom: 0; }

.decision-module { background:#fff; border:1px solid var(--potilas-line); border-radius: var(--radius-xl); box-shadow: var(--shadow-sm); overflow:hidden; }
.decision-row { display:grid; grid-template-columns: 96px minmax(160px,.8fr) minmax(260px,1.7fr) auto; gap:18px; align-items:center; padding:18px 22px; color: var(--potilas-ink); text-decoration:none; border-top:1px solid var(--potilas-line); }
.decision-row:first-child { border-top:0; }
.decision-row:hover { background: linear-gradient(90deg, var(--potilas-mint-soft), #fff); color: var(--potilas-ink); }
.decision-badge { min-width:54px; justify-self:start; height:34px; padding:0 12px; border-radius:999px; display:inline-grid; place-items:center; background:var(--potilas-mint); color:var(--potilas-blue); font-weight:900; letter-spacing:.02em; }
.decision-row.urgent .decision-badge { background: rgba(230,107,91,.13); color:#A93E32; }
.decision-row strong { color: var(--potilas-blue-ink); font-size:1.08rem; }
.decision-row span:not(.decision-badge) { color: var(--potilas-muted); }
.decision-row em { font-style:normal; color:var(--potilas-blue); font-weight:800; white-space:nowrap; }
.feature-grid { align-items: stretch; }
.feature-card { padding: 26px 28px; min-height: 260px; }
.feature-card .feature-icon { margin-bottom: 18px; }
.feature-card h3 a { color: var(--potilas-blue); text-decoration:none; }
.mini-links { list-style:none; padding:18px 0 0; margin:18px 0 0; border-top:1px solid var(--potilas-line); display:grid; gap:8px; }
.mini-links a { text-decoration:none; font-weight:750; color:var(--potilas-blue-ink); }
.mini-links a:hover { color:var(--potilas-blue); }
.mini-links a::before { content:'→'; color:var(--potilas-blue); margin-right:8px; }

.editorial-band { display:grid; grid-template-columns: 1.2fr .8fr; gap: 30px; align-items:center; background: var(--potilas-blue-ink); color:#fff; border-radius: var(--radius-xl); padding: clamp(24px, 4vw, 40px); box-shadow: var(--shadow-md); }
.editorial-band h2 { color:#fff; }
.editorial-band-soft { background: linear-gradient(135deg, var(--potilas-blue-dark), var(--potilas-blue-ink)); }
.editorial-band p { color: #D6E4EF; }
.check-list { list-style:none; padding:0; margin:0; display:grid; gap:12px; }
.check-list li { display:flex; gap:10px; align-items:flex-start; background: rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.12); border-radius: var(--radius-md); padding: 14px 16px; }
.check-list li::before { content:"✓"; color: var(--potilas-mint); font-weight: 950; }

.alert-safe { border-left: 5px solid var(--potilas-coral); background: var(--potilas-mint-soft); padding: 18px 20px; border-radius: var(--radius-md); }
.short-answer { background: var(--potilas-mint-soft); border: 1px solid #CBE9DD; border-radius: var(--radius-lg); padding: 22px; margin: 24px 0; }
.steps { counter-reset: step; display:grid; gap:12px; padding:0; margin:20px 0; list-style:none; }
.steps li { counter-increment: step; background:#fff; border:1px solid var(--potilas-line); border-radius: var(--radius-md); padding:16px 18px 16px 58px; position:relative; }
.steps li::before { content: counter(step); position:absolute; left:16px; top:16px; width:28px; height:28px; border-radius:50%; background:var(--potilas-blue); color:#fff; display:grid; place-items:center; font-weight:900; }

.content-layout { display:grid; grid-template-columns: minmax(0, 1fr) 320px; gap: 34px; align-items:start; }
.article-card { padding: clamp(22px, 4vw, 44px); }
.article-card > *:first-child { margin-top: 0; }
.sidebar { position: sticky; top: 96px; display:grid; gap:18px; }
.meta-row { display:flex; flex-wrap:wrap; gap:10px 16px; color: var(--potilas-muted); font-size:.95rem; }
.breadcrumbs { font-size:.92rem; margin: 20px 0; color: var(--potilas-muted); }
.breadcrumbs a { color: var(--potilas-muted); }
.service-facts { display:grid; grid-template-columns: repeat(2,minmax(0,1fr)); gap:12px; margin: 20px 0; }
.fact { background:#fff; border:1px solid var(--potilas-line); border-radius: var(--radius-md); padding:14px; }
.fact strong { display:block; color: var(--potilas-muted); font-size:.82rem; text-transform:uppercase; letter-spacing:.06em; margin-bottom:4px; }
.service-actions { display:flex; flex-wrap:wrap; gap:10px; margin:20px 0; }
.list-clean { list-style:none; padding:0; margin:0; display:grid; gap:10px; }
.list-clean a { display:flex; justify-content:space-between; gap:12px; padding:12px 0; border-bottom:1px solid var(--potilas-line); text-decoration:none; font-weight:800; }

.filter-panel { margin: 24px 0 0; display:grid; grid-template-columns: repeat(4, minmax(0,1fr)); gap: 12px; }
.filter-panel select, .filter-panel input { width:100%; min-height:46px; border:1px solid var(--potilas-line); border-radius: 14px; padding: 0 14px; background: #fff; font: inherit; }
.service-card-title { margin-bottom: .25rem; }
.service-card-title a { text-decoration: none; color: var(--potilas-blue-ink); }
.service-card-title a:hover { color: var(--potilas-blue); }

.site-footer { background: var(--potilas-blue-ink); color:#DDE7F0; padding:48px 0 28px; margin-top:64px; }
.site-footer a { color:#fff; }
.footer-grid { display:grid; grid-template-columns: 1.3fr repeat(3, 1fr); gap:28px; }
.footer-brand-title { color:#fff; margin-bottom: 12px; }
.footer-disclaimer { color:#BFD3E5; font-size:.95rem; }
.footer-bottom { border-top:1px solid rgba(255,255,255,.14); margin-top:34px; padding-top:20px; color:#B8C7D7; font-size:.92rem; }

@media (max-width: 1120px) {
  .site-nav ul { gap: 11px; }
  .site-nav a { font-size: .9rem; }
}
@media (max-width: 980px) {
  .hero-grid, .content-layout, .footer-grid, .editorial-band { grid-template-columns: 1fr; }
  .sidebar { position: static; }
  .grid-3 { grid-template-columns: repeat(2,minmax(0,1fr)); }
  .decision-row { grid-template-columns: 76px 1fr; }
  .decision-row span:not(.decision-badge), .decision-row em { grid-column: 2; }
  .site-nav { display:none; position:absolute; inset:76px 16px auto 16px; padding:18px; background:#fff; border:1px solid var(--potilas-line); border-radius:var(--radius-lg); box-shadow:var(--shadow-md); }
  .site-nav.is-open { display:block; }
  .site-nav ul { display:grid; gap:12px; align-items:start; }
  .site-nav .header-cta { width: 100%; margin-top: 10px; }
  .mobile-menu-toggle { display:inline-flex; }
  .trust-strip-inner { align-items:flex-start; }
  .filter-panel { grid-template-columns: repeat(2,minmax(0,1fr)); }
}
@media (max-width: 640px) {
  .container { width: min(100% - 24px, var(--container)); }
  .header-inner { min-height: 68px; }
  .brand-name { font-size: 1.12rem; }
  .brand-mark { width: 38px; height: 38px; border-radius: 13px; }
  .search-box { border-radius: var(--radius-lg); flex-direction: column; }
  .search-box button { width:100%; }
  .quick-grid, .grid-2, .grid-3, .service-facts, .filter-panel { grid-template-columns: 1fr; }
  .decision-row { grid-template-columns: 1fr; gap:8px; padding:18px; }
  .decision-row span:not(.decision-badge), .decision-row em { grid-column:auto; }
  .quick-card { min-height: auto; }
  .section-title { display:block; }
  .section-title .button { margin-top: 8px; }
  h1 { font-size: clamp(2.2rem, 10.4vw, 3.35rem); }
  .hero { padding-top: 38px; }
}

@media (prefers-reduced-motion: reduce) { html { scroll-behavior:auto; } *, *::before, *::after { transition:none !important; animation:none !important; } }
@media print { .site-header, .site-footer, .sidebar, .button, .mobile-menu-toggle { display:none !important; } body { background:#fff; color:#000; } .article-card, .card { box-shadow:none; border:1px solid #ddd; } a { color:#000; } }
