/*
Theme Name: Guldager Camping
Theme URI: https://guldagercamping.dk/
Author: ChatGPT
Author URI: https://openai.com/
Description: A modern, nature-inspired WordPress theme for a Danish camping website. Includes a hero homepage, latest-posts discover block, responsive header with search, custom footer menus, search results template, and a travel-styled 404 page.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: guldagercamping
Tags: blog, two-columns, custom-logo, custom-menu, featured-images, translation-ready
*/

:root{
  --bg:#0f1f17;
  --bg-2:#10271c;
  --text:#eef4ef;
  --muted:rgba(238,244,239,.72);
  --line:rgba(238,244,239,.12);
  --accent:#b7e3c2;
  --shadow:0 18px 55px rgba(0,0,0,.32);
  --radius:22px;
  --container:1180px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  color:var(--text);
  background:linear-gradient(180deg,var(--bg) 0%, var(--bg-2) 100%);
  font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  font-size:18px;
  line-height:1.65;
  overflow-x:hidden;
}
@media (max-width:640px){
  body{font-size:17px;}
}
img{max-width:100%;height:auto;display:block}
a{color:var(--accent);text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:3px}
a:hover{opacity:.9}
.container{max-width:var(--container);margin:0 auto;padding:0 22px}

h1,h2,h3,h4{
  font-family:"Playfair Display",Georgia,"Times New Roman",serif;
  letter-spacing:.2px;
  line-height:1.05;
  margin:0 0 14px;
}
h1{font-size:72px}
h2{font-size:52px}
h3{font-size:34px}
@media (max-width:980px){
  h1{font-size:56px}
  h2{font-size:44px}
}
@media (max-width:640px){
  h1{font-size:44px}
  h2{font-size:36px}
  h3{font-size:28px}
}
.subtitle, .wp-block-heading.is-style-subtitle{
  font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  font-size:18px;
  color:var(--muted);
  letter-spacing:.2px;
  line-height:1.7;
}
strong{font-weight:700}
em{font-style:italic}

ul,ol{padding-left:1.2em}
li{margin:.22em 0}
ul li::marker{color:var(--accent)}
ol li::marker{color:var(--accent)}

.site-header{
  position:absolute;top:0;left:0;right:0;z-index:50;
  padding:18px 0;
}
.header-inner{
  display:flex;align-items:center;justify-content:space-between;gap:18px;
}
.brand{display:flex;align-items:center;gap:12px;min-width:210px}
.custom-logo{width:auto;max-height:44px;height:auto}
@media (max-width:980px){.custom-logo{max-height:40px}}
@media (max-width:640px){.custom-logo{max-height:34px}}

.site-title{
  font-family:"Playfair Display",Georgia,serif;
  font-size:26px;letter-spacing:.2px;margin:0;
}
.site-title a{color:var(--text);text-decoration:none}
.nav-wrap{display:flex;align-items:center;gap:18px;flex:1;justify-content:flex-end}
.primary-nav ul{list-style:none;margin:0;padding:0;display:flex;gap:14px;align-items:center}
.primary-nav a{
  display:inline-flex;align-items:center;justify-content:center;
  padding:10px 14px;border-radius:14px;
  background:rgba(255,255,255,.10);
  border:1px solid rgba(255,255,255,.18);
  color:var(--text);text-decoration:none;
  opacity:1;font-size:18px;
}
.primary-nav a:hover{background:rgba(255,255,255,.14);border-color:rgba(255,255,255,.24);}

.header-search{display:flex;align-items:center;gap:10px}
.search-form{display:flex;align-items:center;gap:10px}
.search-form input[type="search"]{
  width:220px;background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.18);
  color:var(--text);
  padding:12px 14px;border-radius:14px;
  outline:none;
}
.search-form input::placeholder{color:rgba(238,244,239,.65)}
.search-form button{
  background:rgba(255,255,255,.14);
  border:1px solid rgba(255,255,255,.22);
  color:var(--text);
  padding:12px 16px;border-radius:14px;
  cursor:pointer;
}
.search-form button:hover{background:rgba(255,255,255,.18)}
.mobile-toggle{
  z-index:90;
  display:none;
  background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.22);
  color:var(--text);
  padding:12px 14px;border-radius:14px;
  cursor:pointer;
}
@media (max-width:920px){
  .primary-nav{display:none}
  .search-form input[type="search"]{width:170px}
  .mobile-toggle{display:inline-flex}
}

.mobile-drawer{
  position:fixed;inset:0;z-index:80;
  background:rgba(0,0,0,.45);
  opacity:0;pointer-events:none;
  transition:opacity .2s ease;
}
.mobile-drawer.is-open{opacity:1;pointer-events:auto}
.mobile-panel{
  position:absolute;top:0;right:0;height:100%;width:min(92vw,420px);
  background:linear-gradient(180deg,#0e2016 0%, #0b1a12 100%);
  border-left:1px solid rgba(255,255,255,.12);
  padding:18px 18px 26px;
  border-top-left-radius:24px;border-bottom-left-radius:24px;
  box-shadow:var(--shadow);
}
.mobile-panel header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.mobile-close{
  background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.2);
  color:var(--text);
  padding:10px 12px;border-radius:12px;
  cursor:pointer;
}
.mobile-nav ul{list-style:none;margin:0;padding:10px 0;display:flex;flex-direction:column;gap:10px}
.mobile-nav a{
  display:block;padding:12px 12px;border-radius:14px;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.10);
  color:var(--text);text-decoration:none;
}
.mobile-nav a:hover{background:rgba(255,255,255,.09)}
.mobile-search{margin-top:14px}

.hero{
  position:relative;min-height:72vh;
  display:flex;align-items:flex-end;
  padding:120px 0 76px;overflow:hidden;
}
.hero-bg{position:absolute;inset:0;background-size:cover;background-position:center}
.hero-overlay{position:absolute;inset:0;background:rgba(13, 44, 28, .66)}
.hero-content{position:relative;z-index:2}
.hero h1{max-width:720px}
.hero .hero-topline{display:flex;align-items:center;gap:14px;margin-bottom:18px;color:var(--muted)}
.pill{
  display:inline-flex;align-items:center;gap:10px;
  padding:10px 14px;border-radius:999px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.14);
  color:rgba(238,244,239,.9);
  font-size:14px;
}
.hero .hero-sub{margin-top:14px;max-width:560px;color:var(--muted)}

.section{padding:72px 0}
.discover{
  display:grid;grid-template-columns:1.2fr 2fr;
  gap:44px;align-items:start;
}
@media (max-width:980px){.discover{grid-template-columns:1fr;gap:26px}}
.discover-left{padding-top:6px}
.discover-left p{color:var(--muted);max-width:420px}
.post-cards{display:grid;grid-template-columns:1fr 1fr;gap:28px}
@media (max-width:700px){.post-cards{grid-template-columns:1fr;gap:18px}}
.card{
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.10);
  border-radius:var(--radius);
  overflow:hidden;
  box-shadow:0 14px 45px rgba(0,0,0,.22);
}
.card .thumb{aspect-ratio:4/3;background:rgba(255,255,255,.06)}
.card .thumb img{width:100%;height:100%;object-fit:cover}
.card .card-body{padding:18px 18px 20px}
.card .card-kicker{color:var(--muted);font-size:16px;margin:0 0 10px}
.card .card-title{
  font-family:"Playfair Display",Georgia,serif;
  font-size:24px;line-height:1.15;margin:0;
}
.card a{color:var(--text);text-decoration:none}
.card a:hover{opacity:.95}
.card .card-meta{margin-top:10px;color:var(--muted);font-size:15px}

.main{padding:56px 0 86px}
.entry-header{margin-bottom:24px}
.entry-title{margin:0}
.entry-meta{color:var(--muted);font-size:15px;margin-top:8px}
.featured{
  border-radius:var(--radius);
  overflow:hidden;
  border:1px solid rgba(255,255,255,.10);
  box-shadow:var(--shadow);
  margin:18px 0 26px;
}

blockquote, .wp-block-quote{
  position:relative;margin:26px 0;
  padding:18px 18px 18px 18px;
  border-left:4px solid rgba(183,227,194,.65);
  background:linear-gradient(180deg, rgba(255,255,255,.06) 0%, rgba(255,255,255,.03) 100%);
  border-radius:18px;
}
blockquote:before{
  content:"“";
  position:absolute;left:14px;top:-16px;
  font-family:"Playfair Display",Georgia,serif;
  font-size:62px;
  color:rgba(183,227,194,.35);
}
blockquote p{margin:0;color:rgba(238,244,239,.88)}
blockquote cite{display:block;margin-top:10px;color:var(--muted);font-style:normal}

table{width:100%;border-collapse:collapse;margin:22px 0;border:1px solid rgba(255,255,255,.12);border-radius:18px;overflow:hidden}
th,td{padding:12px 14px;border-bottom:1px solid rgba(255,255,255,.10);text-align:left}
th{background:rgba(255,255,255,.06);color:rgba(238,244,239,.95)}
tr:last-child td{border-bottom:none}

.wp-block-button__link{
  background:rgba(183,227,194,.18);
  border:1px solid rgba(183,227,194,.35);
  color:var(--text);
  padding:12px 16px;border-radius:14px;
  text-decoration:none;
}
.wp-block-button__link:hover{background:rgba(183,227,194,.22)}

.search-title{margin:0 0 14px}
.search-grid{display:grid;grid-template-columns:1fr;gap:16px;margin-top:18px}
.search-item{
  padding:16px 16px;border-radius:18px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.04);
}
.search-item h3{margin:0 0 8px;font-size:26px}
.search-item p{margin:0;color:var(--muted)}

.site-footer{
  border-top:1px solid rgba(255,255,255,.10);
  padding:44px 0 38px;
  background:rgba(0,0,0,.12);
}
.footer-grid{
  display:grid;grid-template-columns:1.2fr 1fr 1fr;
  gap:26px;align-items:start;
}
@media (max-width:900px){.footer-grid{grid-template-columns:1fr;gap:18px}}
.footer-brand p{color:var(--muted);margin:10px 0 0}
.footer-title{
  font-family:"Playfair Display",Georgia,serif;
  font-size:20px;margin:0 0 12px;
}
.footer-menu ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px}
.footer-menu a{color:rgba(238,244,239,.9);text-decoration:none}
.footer-menu a:hover{opacity:1}
.footer-bottom{margin-top:26px;color:var(--muted);font-size:14px}

.notfound{padding:84px 0 96px;text-align:center}
.notfound .icon{
  width:84px;height:84px;margin:0 auto 18px;
  border-radius:24px;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.12);
  display:grid;place-items:center;
}
.notfound p{color:var(--muted);max-width:560px;margin:12px auto 22px}

.has-hero .site-header{position:absolute}
.no-hero .site-header{
  position:sticky;
  background:rgba(10,20,14,.72);
  backdrop-filter:blur(10px);
  border-bottom:1px solid rgba(255,255,255,.08);
}
.no-hero .site-header .container{padding-top:2px;padding-bottom:2px}


@media (max-width:920px){
  .header-search{display:none;}
  .nav-wrap{gap:12px;}
  .mobile-toggle{display:inline-flex;flex:0 0 auto;}
}



.mobile-search .search-form{width:100%;}
.mobile-search .search-form input[type="search"]{width:100%;min-width:0;}
.mobile-search .search-form button{flex:0 0 auto;white-space:nowrap;}



@media (max-width:920px){
  .brand{min-width:0;}
  .header-inner{gap:12px;}
}

