/*
Theme Name: CarShare
Theme URI: https://example.com/carshare
Author: You
Author URI: https://example.com
Description: CarShare tema s paletom svijetlo plava + bijela. Crni tekst na bijeloj podlozi, bijeli tekst na plavoj.
Version: 1.0.1
Requires at least: 6.0
Tested up to: 6.6
Requires PHP: 7.4
Text Domain: carshare
*/

:root {
  --brand: #3B82F6;      /* svijetlo plava */
  --brand-weak: #60A5FA; /* još svjetlija plava (hover/isticanja) */
  --bg: #FFFFFF;         /* bijela podloga */
  --fg: #111827;         /* crni/tamni tekst */
  --muted: #6b7280;      /* sekundarni tekst */
  --soft: #F3F4F6;       /* svijetlo siva sekcije */
  --border: #e5e7eb;
}

* { box-sizing: border-box; }
body { margin:0; font-family: system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif; color: var(--fg); background: var(--bg); }
a { color: var(--brand); text-decoration: none; }
a:hover { text-decoration: underline; }
.container { width: min(1100px, 92%); margin: 0 auto; }

/* Header */
.site-header { border-bottom: 1px solid var(--border); background:#fff; position: sticky; top:0; z-index: 50; }
.site-header .container { display:flex; align-items:center; justify-content:space-between; gap:16px; padding: 12px 0; }
.logo { font-weight: 700; text-decoration:none; color: var(--fg); }
.main-nav a { color: var(--fg); text-decoration:none; margin: 0 8px; }

.user-nav { margin-left:auto; display:flex; align-items:center; gap:12px; }
.dropdown { position: relative; }
.dropdown-toggle { display:flex; align-items:center; gap:8px; padding:8px 12px; border:1px solid var(--border); background:#fff; border-radius:10px; cursor:pointer; }
.dropdown-menu { position:absolute; right:0; top:calc(100% + 8px); min-width: 280px; background:#fff; border:1px solid var(--border); border-radius:12px; box-shadow: 0 10px 30px rgba(0,0,0,.08); padding:12px; display:none; }
.dropdown-menu.open { display:block; }
.dropdown-menu a { display:block; padding:8px 10px; border-radius:8px; color:var(--fg); text-decoration:none; }
.dropdown-menu a:hover { background:#f3f4f6; }

/* Grids & Cards */
.grid { display:grid; grid-template-columns: repeat(3, 1fr); gap:16px; }
@media (max-width: 900px) { .grid { grid-template-columns: repeat(2, 1fr);} }
@media (max-width: 600px) { .grid { grid-template-columns: 1fr;} }

.card { background:#fff; color: var(--fg); border:1px solid var(--border); border-radius:16px; padding:16px; box-shadow: 0 2px 10px rgba(0,0,0,0.04); }

.form-grid { display:grid; grid-template-columns: 1fr 1fr; gap:12px; }
.form-grid .full { grid-column: 1 / -1; }
input, textarea, select { width:100%; padding:10px 12px; border:1px solid var(--border); border-radius:10px; font: inherit; background:#fff; color: var(--fg); }
label { font-size: 14px; color: var(--muted); }

/* Buttons */
.btn-primary { display:inline-block; padding:10px 14px; border-radius:999px; background: var(--brand); color:#fff; text-decoration:none; border: 1px solid transparent; transition: transform .05s ease, background .2s ease; }
.btn-primary:hover { background: var(--brand-weak); }
.btn-primary:active { transform: translateY(1px); }

.btn-outline { display:inline-block; padding:10px 14px; border-radius:999px; background: #fff; color: var(--brand); border:1px solid var(--brand); }

.btn-link { color: var(--brand); text-decoration: none; }

/* Badges */
.badge { display:inline-block; padding:4px 10px; border-radius:999px; background: var(--brand); color:#fff; font-size:12px; }
.badge-ghost { background: #fff; color: var(--brand); border:1px solid var(--brand); }

/* Hero & CTA sections */
.hero { background: var(--brand); color: #fff; padding: 60px 20px; text-align: center; }
.hero .search-box, .hero form.form-grid { background:#fff; color: var(--fg); padding: 20px; border-radius: 12px; box-shadow: 0 10px 30px rgba(0,0,0,0.08); display:inline-grid; gap:12px; grid-template-columns: 1fr 1fr 1fr auto; }
@media (max-width: 800px) { .hero .search-box, .hero form.form-grid { grid-template-columns: 1fr; } }

.section-soft { background: var(--soft); padding: 30px 16px; border-radius: 16px; }

.cta { background: var(--brand); color: #fff; padding: 40px 20px; text-align: center; border-radius: 16px; }
.cta .btn-primary { background:#fff; color: var(--brand); }

/* Footer */
.footer { border-top:1px solid var(--border); padding:24px 0; color:var(--muted); margin-top:48px; }

/* --- Extras for front page (slider & stats) --- */
.testimonial-slider { position: relative; display:grid; grid-template-columns: 1fr; gap:12px; }
.t-slide { display:none; }
.t-slide.active { display:block; }
.t-dots { display:flex; gap:6px; justify-content:center; margin-top:8px; }
.t-dots button { width:10px; height:10px; border-radius:999px; border:1px solid var(--brand); background:#fff; }
.t-dots button.active { background: var(--brand); }

.stat { text-align:center; }
.stat-num { font-size: 38px; margin: 0; }

/* Popular routes cards heading spacing */
.card h3 { margin-top: 0; }

/* Sticky search bar */
.sticky-search { position: sticky; top: 0; z-index: 60; background: rgba(255,255,255,0.9); backdrop-filter: saturate(180%) blur(8px); border-bottom: 1px solid var(--border); display:none; }
.sticky-search.active { display:block; }
.sticky-search .container { display:flex; align-items:center; justify-content:center; padding: 8px 0; }
.sticky-search form { display:grid; grid-template-columns: 1fr 1fr 160px 160px auto; gap:8px; width:min(1100px, 98%); }
@media (max-width: 900px){ .sticky-search form { grid-template-columns: 1fr; } }

/* FAQ accordion */
.faq .faq-item { border:1px solid var(--border); border-radius:12px; background:#fff; margin-bottom:10px; overflow:hidden; }
.faq .faq-q { width:100%; text-align:left; background:#fff; color:var(--fg); padding:14px 16px; border:none; font-weight:600; cursor:pointer; }
.faq .faq-q:hover { background:#f8fafc; }
.faq .faq-a { display:none; padding: 0 16px 14px; color: var(--fg); }
.faq .faq-item.open .faq-a { display:block; }

/* Map card */
#rides-map { background:#eef2ff; }

/* Blog cards fix */
.post .entry-title, .post h3 a { color: var(--fg); }


/* ==== Pretty mobile header (off-canvas) - minimal patch ==== */
.header{ position:sticky; top:0; z-index:1000; box-shadow:0 2px 10px rgba(17,24,39,.06); }
@media (min-width:769px){
  .mobile-nav, .mobile-overlay, .mobile-drawer{ display:none !important; }
}
@media (max-width:768px){
  .header{ padding:6px 12px; }
  .header .main-nav{ display:none !important; }
}
.mobile-overlay{ position:fixed; inset:0; background:rgba(0,0,0,.4); z-index:998; opacity:0; transition:opacity .2s ease; }
.mobile-overlay.is-open{ opacity:1; }
.mobile-drawer{ position:fixed; top:0; right:0; height:100%; width:84%; max-width:360px; background:#fff; z-index:999; transform:translateX(100%); transition:transform .25s ease; box-shadow: -6px 0 20px rgba(17,24,39,.15); display:flex; flex-direction:column; }
.mobile-drawer.is-open{ transform:translateX(0); }
.mobile-drawer__header{ display:flex; align-items:center; justify-content:space-between; padding:14px 16px; border-bottom:1px solid #eef2f7; }
.drawer-close{ font-size:26px; line-height:1; background:transparent; border:0; cursor:pointer; padding:6px 10px; border-radius:10px; }
.drawer-close:hover{ background:#f5f7fb; }
.mobile-nav{ padding:8px 0 16px; overflow:auto; }
.mobile-nav .menu{ list-style:none; margin:0; padding:0; }
.mobile-nav .menu > li > a{ display:block; padding:14px 16px; text-decoration:none; color:#111; }
.mobile-nav .menu > li > a:hover{ background:#f5f7fb; }
.mobile-nav .menu li{ border-bottom:1px solid #f1f5f9; }
.nav-toggle{ display:inline-flex; align-items:center; justify-content:center; background:#fff; border:1px solid #e2e8f0; padding:10px; border-radius:12px; box-shadow:0 1px 2px rgba(0,0,0,.03); }
.nav-toggle .bar{ width:24px; height:2px; background:#111; margin:4px 0; border-radius:1px; }



/* Logo-only header */
.site-title, .header .site-title, .site-brand .site-title { display:none !important; }
.site-brand img.custom-logo{ height:48px; width:auto; display:block; }
@media (max-width:768px){ .site-brand img.custom-logo{ height:36px; } }
.mobile-drawer__header img.custom-logo{ height:28px; width:auto; display:block; }



/* ===== Pro 3-zone header ===== */
:root{ --brand:#4da3ff; --text:#0f172a; --muted:#64748b; --bg:#fff; --line:#eef2f7; }
.site-header{ position:sticky; top:0; z-index:1000; background:var(--bg); border-bottom:1px solid var(--line); }
.site-header.is-scrolled{ box-shadow:0 8px 22px rgba(2,6,23,.06); }
.header-grid{ max-width:1200px; margin:0 auto; padding:10px 16px; display:grid; grid-template-columns: 1fr auto; align-items:center; gap:16px; }
.brand{ justify-self:start; }
.brand img.custom-logo{ height:var(--logo-h-desktop, 48px); width:auto; display:block; }
.logo-align-center .brand{ justify-self:center; }
.logo-align-right .brand{ justify-self:end; }
.main-nav{ justify-self:center; }
.main-nav .menu{ display:flex; gap:22px; align-items:center; margin:0; padding:0; list-style:none; }
.main-nav .menu a{ color:var(--text); text-decoration:none; padding:10px 12px; border-radius:12px; font-weight:600; transition: background .18s, color .18s, transform .12s; }
.main-nav .menu a:hover,
.main-nav .menu .current-menu-item>a{ background:#f0f6ff; color:var(--brand); }
.actions{ justify-self:end; display:flex; align-items:center; gap:10px; position:relative; }
.btn-ghost{ border:1px solid var(--line); padding:9px 12px; border-radius:12px; background:#fff; color:var(--text); text-decoration:none; display:inline-flex; gap:8px; align-items:center; min-height:40px; }
.btn-ghost:hover{ background:#f8fbff; }
.btn-cta{ background:var(--brand); color:#fff; border-radius:12px; padding:10px 14px; text-decoration:none; font-weight:700; min-height:40px; box-shadow:0 6px 14px rgba(77,163,255,.25); }
.btn-cta:hover{ transform:translateY(-1px); box-shadow:0 8px 18px rgba(77,163,255,.32); }
.user-toggle{ display:flex; align-items:center; gap:6px; background:#fff; border:1px solid var(--line); padding:8px 10px; border-radius:999px; cursor:pointer; min-height:40px; }
.user-menu{ position:absolute; top:calc(100% + 8px); right:0; min-width:200px; background:#fff; border:1px solid var(--line); border-radius:12px; box-shadow:0 12px 30px rgba(2,6,23,.08); padding:6px; display:none; }
.user-menu a{ display:block; padding:10px 12px; border-radius:10px; color:var(--text); text-decoration:none; }
.user-menu a:hover{ background:#f5f8ff; }
.user-toggle[aria-expanded="true"] + .user-menu{ display:block; }
.nav-toggle{ display:none; background:#fff; border:1px solid var(--line); padding:10px; border-radius:12px; }
.nav-toggle .bar{ width:24px; height:2px; background:#111; margin:4px 0; border-radius:1px; }
.i{ display:inline-block; }
.i-search::before{ content:"🔎"; }

/* mobile */
@media (max-width:1024px){
  .main-nav{ display:none; }
  .nav-toggle{ display:inline-flex; }
  .header-grid{ grid-template-columns: 1fr auto; }
}
@media (max-width:768px){
  .header-grid{ padding:8px 12px; }
  .brand img.custom-logo{ height:var(--logo-h-mobile, 36px); }
}

/* Off-canvas polish (already exists) */
.mobile-overlay{ position:fixed; inset:0; background:rgba(0,0,0,.4); z-index:998; opacity:0; transition:opacity .2s ease; }
.mobile-overlay.is-open{ opacity:1; }
.mobile-drawer{ position:fixed; top:0; right:0; height:100%; width:86%; max-width:360px; background:#fff; z-index:999; transform:translateX(100%); transition:transform .25s ease; box-shadow:-6px 0 20px rgba(17,24,39,.15); display:flex; flex-direction:column; }
.mobile-drawer.is-open{ transform:translateX(0); }
.mobile-drawer__header{ display:flex; align-items:center; justify-content:space-between; padding:14px 16px; border-bottom:1px solid var(--line); }
.mobile-actions{ padding:12px; border-top:1px solid var(--line); display:flex; gap:8px; }

/* A11y: focus ring */
:focus-visible{ outline:2px solid var(--brand); outline-offset:2px; }
@media (prefers-reduced-motion: reduce){ *{ transition:none !important; } }


/* No-navigation variant */
.main-nav{ display:none !important; }
.nav-toggle{ display:none !important; }
.mobile-overlay, .mobile-drawer{ display:none !important; }


/* Progress bars */
.progress{ position:relative; height:12px; background:#f1f5f9; border-radius:999px; overflow:hidden; margin:6px 0 2px; }
.progress .bar{ position:absolute; left:0; top:0; bottom:0; width:0; background:#4da3ff; }
.progress .progress-text{ font-size:12px; color:#0f172a; margin-top:4px; }
.progress-mini{ position:relative; height:8px; background:#f1f5f9; border-radius:999px; overflow:hidden; min-width:100px; }
.progress-mini .bar{ position:absolute; left:0; top:0; bottom:0; background:#4da3ff; }
.progress-mini .txt{ font-size:12px; color:#0f172a; margin-left:6px; }


/* Moje vožnje template basic helpers */
.chips{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:12px}
.chip{display:inline-flex;align-items:center;gap:6px;padding:8px 10px;border-radius:999px;background:#f5f7fb;text-decoration:none;color:#111}
.chip.active{background:#e6f2ff}


/* Dodaj vožnju form */
.form-grid label span{ display:block; font-weight:600; margin-bottom:6px; }
.form-grid input, .form-grid select, .form-grid textarea{ width:100%; border:1px solid #e2e8f0; border-radius:10px; padding:10px; }
.form-grid label.has-error input, .form-grid label.has-error select, .form-grid label.has-error textarea{ border-color:#ef4444; background:#fff7f7; }
.terms{ display:flex; gap:8px; align-items:center; margin-top:10px; }


/* Inline add-ride tweaks: nothing additional needed */


/* Add-ride enhancements */
#quick-chips .chip{ cursor:pointer; }
.btn-outline{ border:1px solid #cbd5e1; background:#fff; padding:6px 10px; border-radius:10px; text-decoration:none; color:#0f172a; display:inline-flex; align-items:center; }
.btn-outline:hover{ background:#f8fbff; }



/* Chips with inputs */
.chips .chip{display:inline-flex;align-items:center;gap:6px;padding:8px 10px;border-radius:999px;background:#f5f7fb;border:1px solid #e5eaf0;cursor:pointer;margin:4px 6px 0 0}
.chips .chip input{margin:0}
.chips .chip:hover{background:#eef6ff}
.ride-badges .chip{background:#eef6ff;border:1px solid #dbeafe}



/* Single Ride layout helpers */
.ride-single .chip{display:inline-flex;align-items:center;gap:6px;padding:8px 10px;border-radius:999px;background:#f5f7fb;border:1px solid #e5eaf0;color:#0f172a}
.btn-cta{background:#1d4ed8;color:#fff;border:none;border-radius:10px;padding:8px 12px;cursor:pointer;text-decoration:none}
.btn-cta:hover{opacity:.95}
.btn-outline{border:1px solid #cbd5e1;background:#fff;padding:6px 10px;border-radius:10px;text-decoration:none;color:#0f172a;display:inline-flex;align-items:center}
.btn-outline:hover{background:#f8fbff}



/* ======= Carshare Beauty Pack ======= */
:root{
  --cs-bg:#ffffff;
  --cs-surface:#ffffff;
  --cs-soft:#f1f7ff; /* light blue pillow */
  --cs-border:#e5eaf0;
  --cs-text:#0f172a;
  --cs-muted:#475569;
  --cs-accent:#1d4ed8; /* mid blue */
  --cs-accent-2:#60a5fa; /* lighter */
  --cs-shadow: 0 6px 18px rgba(15,23,42,.07);
  --cs-radius:14px;
}
*{box-sizing:border-box}
body{background:var(--cs-bg);color:var(--cs-text)}
h1,h2,h3{line-height:1.2;color:var(--cs-text)}
h1{font-size:clamp(22px,3.5vw,32px)}
h2{font-size:clamp(18px,3vw,24px)}
h3{font-size:clamp(16px,2.5vw,20px)}
.container{max-width:1100px;margin:0 auto;padding:0 16px}
.card{background:var(--cs-surface);border:1px solid var(--cs-border);border-radius:var(--cs-radius);padding:16px;box-shadow:var(--cs-shadow)}
.pillow{background:var(--cs-soft);border:1px solid var(--cs-border);border-radius:var(--cs-radius)}
.btn, .btn-cta, .btn-outline, .btn-ghost{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  border-radius:12px;padding:10px 14px;cursor:pointer;text-decoration:none;transition:.2s ease;
}
.btn-cta{background:var(--cs-accent);color:#fff;border:1px solid var(--cs-accent)}
.btn-cta:hover{filter:brightness(.98);transform:translateY(-1px)}
.btn-outline{background:#fff;color:var(--cs-text);border:1px solid var(--cs-border)}
.btn-outline:hover{background:var(--cs-soft)}
.btn-ghost{background:transparent;color:var(--cs-accent);border:1px dashed var(--cs-accent-2)}
.btn-ghost:hover{background:#eef6ff}
.chip{display:inline-flex;align-items:center;gap:6px;padding:8px 10px;border-radius:999px;background:#f5f7fb;border:1px solid var(--cs-border);color:var(--cs-text)}
.stat{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:12px;background:#f8fbff;border:1px solid var(--cs-border)}
.progress{height:9px;background:#eef2f7;border-radius:999px;overflow:hidden}
.progress > span{display:block;height:100%;background:linear-gradient(90deg,var(--cs-accent),var(--cs-accent-2))}
.grid{display:grid;gap:14px}
.grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}
.grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}
@media (max-width: 720px){
  .grid-2,.grid-3{grid-template-columns:1fr}
}
.hero{
  border-radius:calc(var(--cs-radius) + 8px);
  background:linear-gradient(180deg,#f4faff 0%, #ffffff 55%);
  border:1px solid var(--cs-border);
  box-shadow:var(--cs-shadow);
  padding:18px;
}
.hero .title{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;flex-wrap:wrap}
.hero .meta{display:flex;gap:8px;flex-wrap:wrap}
.hero .price-cta{display:flex;gap:8px;flex-wrap:wrap}
.sticky-cta{
  position:fixed;left:0;right:0;bottom:12px;z-index:50;
  display:none;justify-content:center;
}
.sticky-cta .bar{
  backdrop-filter:saturate(160%) blur(8px);
  background:rgba(255,255,255,.92);border:1px solid var(--cs-border);box-shadow:var(--cs-shadow);
  border-radius:16px;padding:10px;display:flex;gap:8px;align-items:center;
}
@media (max-width: 900px){ .sticky-cta{display:flex} }
.kv{display:flex;align-items:center;gap:8px}
.kv .k{color:var(--cs-muted)}
.table-clean{width:100%;border-collapse:separate;border-spacing:0 8px}
.table-clean tr td{background:#fff;border:1px solid var(--cs-border);padding:10px 12px}
.table-clean tr td:first-child{border-top-left-radius:12px;border-bottom-left-radius:12px}
.table-clean tr td:last-child{border-top-right-radius:12px;border-bottom-right-radius:12px}
.leaflet-container{border-radius:12px;border:1px solid var(--cs-border)}
/* Add-ride form small tweaks to match */
.form-grid input,.form-grid select,.form-grid textarea{border-radius:12px}



/* Front Auth forms */
label > input, label > select, label > textarea{
  width:100%;padding:10px 12px;border:1px solid var(--cs-border);border-radius:12px;
}
.tabs .btn-outline{padding:6px 10px}



/* Moj profil tabs enhancements */
.card .btn-outline[href^="#tab-"]{padding:6px 10px}
.card h4{font-size:16px}



/* Profile Fullpack */
.card h4{font-size:16px}
fieldset{border:1px solid var(--cs-border);padding:8px;border-radius:12px}
legend{padding:0 6px;color:#475569}
label > input, label > select, label > textarea{width:100%;padding:10px 12px;border:1px solid var(--cs-border);border-radius:12px}


/* Threads */
.pillow .meta{font-size:12px;color:#64748b}

/* Header unread bell */
#cs-unread a{display:inline-flex;align-items:center;gap:6px}
#cs-unread-count{font-size:12px}
