/*
 Theme Name:   Carstens MC Child
 Theme URI:    https://carstensmc.dk
 Description:  Child theme til Hello Elementor — Yamaha Racing Blue motorcykelkatalog.
 Author:       Refokus
 Author URI:   https://refokus.nu
 Template:     hello-elementor
 Version:      4.0.0
 Text Domain:  carstens-mc-child
*/

:root {
  --cmc-blue: #0046BE;
  --cmc-blue-l: #1A5FD0;
  --cmc-blue-b: #3378E0;
  --cmc-blue-dim: rgba(0,70,190,0.10);
  --cmc-blue-bdr: rgba(0,70,190,0.25);
  --cmc-bg: #06080C;
  --cmc-card: #0D1117;
  --cmc-input: #111820;
  --cmc-bdr: #1B2332;
  --cmc-bdr-h: #2A3648;
  --cmc-t1: #EFF2F6;
  --cmc-t2: #8B95A5;
  --cmc-t3: #4A5568;
  --cmc-r: 10px;
  --cmc-ease: 0.25s cubic-bezier(0.4,0,0.2,1);
}

/* === WRAPPER — alleen hier donker === */
.cmc-wrap { background:var(--cmc-bg); color:var(--cmc-t1); font-family:'Outfit',sans-serif; line-height:1.5; -webkit-font-smoothing:antialiased; padding:0 0 60px; }
.cmc-wrap *, .cmc-wrap *::before, .cmc-wrap *::after { box-sizing:border-box; }
.cmc-wrap a { color:inherit; text-decoration:none; }

/* === YAMAHA BAR === */
.cmc-yamaha-bar { background:linear-gradient(90deg,var(--cmc-blue),#003DA5); padding:10px 24px; font-size:12px; font-weight:600; color:white; display:flex; align-items:center; justify-content:center; gap:14px; margin-bottom:28px; }
.cmc-dot { width:4px; height:4px; background:rgba(255,255,255,0.4); border-radius:50%; }

/* === TOOLBAR === */
.cmc-toolbar { max-width:1400px; margin:0 auto; padding:0 24px 16px; display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:12px; }
.cmc-toolbar-count { font-size:14px; color:var(--cmc-t2); }
.cmc-toolbar-count strong { color:var(--cmc-t1); }
.cmc-sort { background:var(--cmc-input); border:1px solid var(--cmc-bdr); color:var(--cmc-t1); padding:10px 36px 10px 14px; border-radius:6px; font-family:inherit; font-size:13px; cursor:pointer; outline:none; appearance:none; background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%238B95A5' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right 12px center; }

/* === MOBILE TOGGLE === */
.cmc-toggle-wrap { max-width:1400px; margin:0 auto; padding:0 24px; }
.cmc-filter-toggle { display:none; width:100%; padding:14px; background:var(--cmc-card); border:1px solid var(--cmc-bdr); border-radius:var(--cmc-r); color:var(--cmc-t1); font-family:'Outfit',sans-serif; font-size:15px; font-weight:600; cursor:pointer; text-align:center; touch-action:manipulation; -webkit-tap-highlight-color:rgba(0,70,190,0.2); }
.cmc-filter-toggle:active { background:var(--cmc-bdr); }

/* === LAYOUT === */
.cmc-layout { max-width:1400px; margin:0 auto; padding:0 24px; display:grid; grid-template-columns:260px 1fr; gap:28px; }

/* === SIDEBAR === */
.cmc-sidebar { position:sticky; top:90px; height:fit-content; max-height:calc(100vh - 110px); overflow-y:auto; scrollbar-width:thin; scrollbar-color:var(--cmc-bdr) transparent; }
.cmc-filter-box { background:var(--cmc-card); border:1px solid var(--cmc-bdr); border-radius:var(--cmc-r); padding:16px; margin-bottom:10px; }
.cmc-filter-title { font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:1.2px; color:var(--cmc-t3); margin-bottom:12px; }
.cmc-filter-search input { width:100%; background:var(--cmc-input); border:1px solid var(--cmc-bdr); color:var(--cmc-t1); padding:10px 14px; border-radius:6px; font-family:inherit; font-size:14px; outline:none; }
.cmc-filter-search input:focus { border-color:var(--cmc-blue); }
.cmc-filter-search input::placeholder { color:var(--cmc-t3); }

/* Pills (stand, ccm, hk) */
.cmc-pills { display:flex; flex-wrap:wrap; gap:6px; }
.cmc-pill { padding:6px 14px; border-radius:100px; font-size:12px; font-weight:500; border:1px solid var(--cmc-bdr); background:transparent; color:var(--cmc-t2); cursor:pointer; font-family:inherit; transition:all var(--cmc-ease); }
.cmc-pill:hover { border-color:var(--cmc-bdr-h); color:var(--cmc-t1); }
.cmc-pill.active { border-color:var(--cmc-blue); background:var(--cmc-blue-dim); color:var(--cmc-blue-b); }

/* Checkboxes (mærke, kategori) — BUTTONS not divs */
.cmc-checks { display:flex; flex-direction:column; gap:2px; }
.cmc-check { display:flex; align-items:center; gap:10px; padding:8px 10px; border-radius:6px; cursor:pointer; border:none; background:transparent; font-family:inherit; text-align:left; width:100%; transition:background var(--cmc-ease); }
.cmc-check:hover { background:var(--cmc-input); }
.cmc-checkbox { width:16px; height:16px; border:2px solid var(--cmc-bdr-h); border-radius:3px; flex-shrink:0; position:relative; transition:all var(--cmc-ease); }
.cmc-check.active .cmc-checkbox { background:var(--cmc-blue); border-color:var(--cmc-blue); }
.cmc-check.active .cmc-checkbox::after { content:'✓'; position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); font-size:10px; color:white; font-weight:700; }
.cmc-check-label { font-size:13px; color:var(--cmc-t2); flex:1; }
.cmc-check.active .cmc-check-label { color:var(--cmc-t1); }
.cmc-check-count { font-size:11px; color:var(--cmc-t3); font-family:'Space Mono',monospace; }

/* === MC CARDS === */
.cmc-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(300px,1fr)); gap:14px; }
.cmc-card { background:var(--cmc-card); border:1px solid var(--cmc-bdr); border-radius:var(--cmc-r); overflow:hidden; transition:all var(--cmc-ease); }
.cmc-card:hover { border-color:var(--cmc-bdr-h); transform:translateY(-3px); box-shadow:0 16px 48px rgba(0,0,0,0.4); }
.cmc-card a { text-decoration:none !important; color:inherit !important; }
.cmc-card-img { position:relative; aspect-ratio:4/3; overflow:hidden; background:#080C12; }
.cmc-card-img img { width:100%; height:100%; object-fit:cover; transition:transform 0.5s; }
.cmc-card:hover .cmc-card-img img { transform:scale(1.04); }
.cmc-card-badges { position:absolute; top:10px; left:10px; display:flex; gap:5px; }
.cmc-badge { padding:4px 10px; border-radius:100px; font-size:10px; font-weight:700; text-transform:uppercase; letter-spacing:0.3px; }
.cmc-badge-new { background:var(--cmc-blue); color:white; }
.cmc-badge-used { background:rgba(255,255,255,0.14); backdrop-filter:blur(8px); color:white; }
.cmc-badge-yam { background:rgba(0,70,190,0.85); backdrop-filter:blur(8px); color:white; }
.cmc-card-body { padding:16px; }
.cmc-card-top { display:flex; justify-content:space-between; gap:10px; margin-bottom:10px; }
.cmc-card-title { font-size:16px; font-weight:700; line-height:1.2; }
.cmc-card-sub { font-size:12px; color:var(--cmc-t3); margin-top:2px; }
.cmc-card-right { text-align:right; flex-shrink:0; }
.cmc-card-price { font-family:'Space Mono',monospace; font-size:17px; font-weight:700; white-space:nowrap; }
.cmc-card-fin { font-size:10px; color:var(--cmc-t3); margin-top:1px; }
.cmc-card-specs { display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--cmc-bdr); border-radius:6px; overflow:hidden; margin-bottom:12px; }
.cmc-spec { background:var(--cmc-card); padding:8px 4px; text-align:center; }
.cmc-spec b { font-family:'Space Mono',monospace; font-size:13px; display:block; }
.cmc-spec small { font-size:9px; color:var(--cmc-t3); text-transform:uppercase; letter-spacing:0.5px; }
.cmc-card-bottom { display:flex; align-items:center; justify-content:space-between; }
.cmc-card-tags { display:flex; gap:4px; flex-wrap:wrap; }
.cmc-tag { font-size:10px; padding:3px 8px; border-radius:100px; background:var(--cmc-input); color:var(--cmc-t3); border:1px solid var(--cmc-bdr); }
.cmc-card-arrow { width:32px; height:32px; border-radius:50%; background:var(--cmc-input); border:1px solid var(--cmc-bdr); display:flex; align-items:center; justify-content:center; color:var(--cmc-t3); font-size:14px; transition:all var(--cmc-ease); flex-shrink:0; }
.cmc-card:hover .cmc-card-arrow { background:var(--cmc-blue); border-color:var(--cmc-blue); color:white; }


/* =============================================
   PRODUCT PAGE (single-motorcycle.php)
   ============================================= */
.cmc-wrap .cmc-bc { max-width:1200px; margin:0 auto; padding:16px 24px; font-size:13px; color:var(--cmc-t3); display:flex; gap:8px; flex-wrap:wrap; }
.cmc-wrap .cmc-bc a { color:var(--cmc-t2); }
.cmc-wrap .cmc-bc a:hover { color:var(--cmc-blue-b); }

.cmc-wrap .cmc-pg { max-width:1200px; margin:0 auto; padding:0 24px; display:grid; grid-template-columns:1fr 380px; gap:32px; align-items:start; }
.cmc-wrap .cmc-pg-img { position:relative; border-radius:12px; overflow:hidden; background:#0D1117; max-height:440px; }
.cmc-wrap .cmc-pg-img img { width:100%; height:100%; object-fit:cover; display:block; max-height:440px; }
.cmc-wrap .cmc-pg-badges { position:absolute; top:12px; left:12px; display:flex; gap:6px; }
.cmc-wrap .cmc-pg-cat { position:absolute; bottom:12px; right:12px; background:rgba(0,0,0,0.65); backdrop-filter:blur(8px); padding:5px 14px; border-radius:100px; font-size:12px; color:white; }

.cmc-wrap .cmc-pg-side { position:sticky; top:90px; }
.cmc-wrap .cmc-pg-card { background:var(--cmc-card); border:1px solid var(--cmc-bdr); border-radius:12px; padding:28px; margin-bottom:12px; }
.cmc-wrap .cmc-pg-brand { font-size:11px; font-weight:700; color:var(--cmc-t3); text-transform:uppercase; letter-spacing:1.5px; margin-bottom:6px; }
.cmc-wrap .cmc-pg-card h1 { font-size:24px; font-weight:800; line-height:1.15; letter-spacing:-0.5px; margin:0 0 4px; }
.cmc-wrap .cmc-pg-sub { font-size:13px; color:var(--cmc-t2); margin-bottom:20px; }
.cmc-wrap .cmc-pg-pricebox { background:var(--cmc-input); border:1px solid var(--cmc-bdr); border-radius:8px; padding:18px; margin-bottom:20px; }
.cmc-wrap .cmc-pg-price { font-family:'Space Mono',monospace; font-size:28px; font-weight:700; }
.cmc-wrap .cmc-pg-fin { font-size:12px; color:var(--cmc-t2); margin-top:4px; }
.cmc-wrap .cmc-pg-fin a { color:var(--cmc-blue-b); text-decoration:underline; text-underline-offset:2px; }
.cmc-wrap .cmc-pg-ctas { display:flex; flex-direction:column; gap:8px; margin-bottom:20px; }
.cmc-wrap .cmc-pg-cta1 { display:flex; align-items:center; justify-content:center; gap:8px; padding:14px; background:var(--cmc-blue); color:white; border-radius:8px; font-size:15px; font-weight:700; transition:background 0.2s; }
.cmc-wrap .cmc-pg-cta1:hover { background:var(--cmc-blue-l); }
.cmc-wrap .cmc-pg-cta2 { display:flex; align-items:center; justify-content:center; gap:8px; padding:14px; color:var(--cmc-t1); border:1px solid var(--cmc-bdr); border-radius:8px; font-size:13px; font-weight:600; transition:background 0.2s; }
.cmc-wrap .cmc-pg-cta2:hover { background:var(--cmc-input); }
.cmc-wrap .cmc-pg-contact { display:flex; align-items:center; gap:12px; padding:14px; background:var(--cmc-input); border-radius:8px; border:1px solid var(--cmc-bdr); }
.cmc-wrap .cmc-pg-av { width:40px; height:40px; border-radius:50%; background:linear-gradient(135deg,var(--cmc-blue),var(--cmc-blue-l)); display:flex; align-items:center; justify-content:center; font-size:14px; font-weight:700; color:white; flex-shrink:0; }

.cmc-wrap .cmc-pg-trust { background:var(--cmc-card); border:1px solid var(--cmc-bdr); border-radius:12px; padding:20px; }
.cmc-wrap .cmc-pg-ti { display:flex; gap:12px; padding:10px 0; }
.cmc-wrap .cmc-pg-ti + .cmc-pg-ti { border-top:1px solid var(--cmc-bdr); }
.cmc-wrap .cmc-pg-ti-icon { width:36px; height:36px; border-radius:6px; background:var(--cmc-input); display:flex; align-items:center; justify-content:center; font-size:16px; flex-shrink:0; }
.cmc-wrap .cmc-pg-ti-t { font-size:13px; font-weight:600; }
.cmc-wrap .cmc-pg-ti-s { font-size:11px; color:var(--cmc-t3); }

.cmc-wrap .cmc-pg-content { max-width:1200px; margin:0 auto; padding:40px 24px 0; display:grid; grid-template-columns:1fr 380px; gap:32px; }
.cmc-wrap .cmc-pg-content h2 { font-size:18px; font-weight:700; margin:0 0 14px; }
.cmc-wrap .cmc-pg-desc { font-size:14px; line-height:1.8; color:var(--cmc-t2); }
.cmc-wrap .cmc-pg-desc p { margin-bottom:10px; }
.cmc-wrap .cmc-pg-table { width:100%; border-collapse:collapse; }
.cmc-wrap .cmc-pg-table tr { border-bottom:1px solid var(--cmc-bdr); }
.cmc-wrap .cmc-pg-table td { padding:11px 0; font-size:13px; }
.cmc-wrap .cmc-pg-table td:first-child { color:var(--cmc-t3); width:140px; }
.cmc-wrap .cmc-pg-table td:last-child { font-weight:600; }

.cmc-wrap .cmc-pg-related { max-width:1200px; margin:0 auto; padding:48px 24px 0; }
.cmc-wrap .cmc-pg-rel-head { display:flex; justify-content:space-between; align-items:center; margin-bottom:20px; }
.cmc-wrap .cmc-pg-rel-head h2 { font-size:20px; font-weight:800; margin:0; }
.cmc-wrap .cmc-pg-rel-head a { color:var(--cmc-blue-b); font-size:13px; font-weight:600; }
.cmc-wrap .cmc-pg-rel-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:12px; }
.cmc-wrap .cmc-rc { background:var(--cmc-card); border:1px solid var(--cmc-bdr); border-radius:var(--cmc-r); overflow:hidden; transition:all var(--cmc-ease); }
.cmc-wrap .cmc-rc:hover { border-color:var(--cmc-bdr-h); transform:translateY(-2px); }
.cmc-wrap .cmc-rc-img { aspect-ratio:16/10; overflow:hidden; }
.cmc-wrap .cmc-rc-img img { width:100%; height:100%; object-fit:cover; }
.cmc-wrap .cmc-rc-body { padding:12px; }
.cmc-wrap .cmc-rc-title { font-size:14px; font-weight:700; margin-bottom:2px; }
.cmc-wrap .cmc-rc-sub { font-size:11px; color:var(--cmc-t3); margin-bottom:8px; }
.cmc-wrap .cmc-rc-bottom { display:flex; justify-content:space-between; align-items:center; }
.cmc-wrap .cmc-rc-price { font-family:'Space Mono',monospace; font-size:14px; font-weight:700; }
.cmc-wrap .cmc-rc-specs { font-size:10px; color:var(--cmc-t3); }


/* =============================================
   RESPONSIVE
   ============================================= */
@media(max-width:960px) {
  .cmc-layout { grid-template-columns:1fr; }
  .cmc-sidebar { position:static; max-height:0; overflow:hidden; opacity:0; transition:max-height 0.35s ease, opacity 0.35s ease; }
  .cmc-sidebar.open { max-height:3000px; opacity:1; }
  .cmc-filter-toggle { display:block; margin-bottom:16px; }
  .cmc-toolbar, .cmc-toggle-wrap, .cmc-layout { padding-left:16px; padding-right:16px; }
  .cmc-yamaha-bar { font-size:11px; gap:10px; }

  /* Product */
  .cmc-wrap .cmc-pg { grid-template-columns:1fr; gap:20px; padding-left:16px; padding-right:16px; }
  .cmc-wrap .cmc-pg-side { position:static; }
  .cmc-wrap .cmc-pg-content { grid-template-columns:1fr; padding-left:16px; padding-right:16px; }
  .cmc-wrap .cmc-pg-related { padding-left:16px; padding-right:16px; }
  .cmc-wrap .cmc-pg-rel-grid { grid-template-columns:1fr 1fr; }
  .cmc-wrap .cmc-pg-img, .cmc-wrap .cmc-pg-img img { max-height:360px; }
}

@media(max-width:640px) {
  .cmc-grid { grid-template-columns:1fr; }
  .cmc-yamaha-bar span:nth-child(n+4) { display:none; }
  .cmc-yamaha-bar .cmc-dot:nth-child(n+4) { display:none; }

  /* Product small */
  .cmc-wrap .cmc-pg-img, .cmc-wrap .cmc-pg-img img { max-height:240px; }
  .cmc-wrap .cmc-pg-card h1 { font-size:22px; }
  .cmc-wrap .cmc-pg-price { font-size:24px; }
  .cmc-wrap .cmc-pg-card { padding:20px; }
  .cmc-wrap .cmc-pg, .cmc-wrap .cmc-pg-content, .cmc-wrap .cmc-pg-related, .cmc-wrap .cmc-bc { padding-left:12px; padding-right:12px; }

  /* Related horizontal cards */
  .cmc-wrap .cmc-pg-rel-grid { grid-template-columns:1fr; }
  .cmc-wrap .cmc-rc { display:flex; }
  .cmc-wrap .cmc-rc-img { aspect-ratio:1/1; width:110px; flex-shrink:0; }
  .cmc-wrap .cmc-rc-body { display:flex; flex-direction:column; justify-content:center; padding:10px; }

  /* Search results */
  .cmc-result-card { grid-template-columns:1fr !important; }
}
