/*
Theme Name: Travel Focus
Theme URI: https://travelfocus.nl
Author: Feeling Content
Author URI: https://lincker.io
Description: Een levendig, fotografie-gedreven reisblogthema. Grote beelden, een centrale zoekbalk, bestemmingstegels en een artikelweergave met meescrollende inhoudsopgave, leesbalk en een kompas in de menubalk dat de cursor volgt. Codenaam: Brandpunt.
Version: 1.0.1
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: travelfocus
Tags: blog, custom-logo, custom-menu, featured-images, full-width-template, threaded-comments, translation-ready, right-sidebar
*/

:root{
  --tf-bg:#FBF7F0;
  --tf-surface:#FFFFFF;
  --tf-ink:#1A1B1E;
  --tf-ink-soft:#39362F;
  --tf-ink2:#6A6660;
  --tf-coral:#F1502C;
  --tf-coral-ink:#B53415;
  --tf-teal:#0E8A86;
  --tf-line:#ECE4D6;
  --tf-line-soft:#F0EBE1;
  --tf-night:#152A24;
  --tf-radius:13px;
  --tf-radius-sm:9px;
  --tf-wrap:1180px;
  --tf-font-display:"Bricolage Grotesque",ui-sans-serif,system-ui,sans-serif;
  --tf-font-body:"DM Sans",ui-sans-serif,system-ui,sans-serif;
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  background:var(--tf-bg);
  color:var(--tf-ink);
  font-family:var(--tf-font-body);
  font-size:17px;
  line-height:1.72;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--tf-coral-ink);text-decoration:none}
a:hover{text-decoration:underline}

.tf-wrap{max-width:var(--tf-wrap);margin:0 auto;padding:0 22px}
.tf-display{font-family:var(--tf-font-display);letter-spacing:-0.02em;line-height:1.06}
.screen-reader-text{position:absolute!important;width:1px;height:1px;overflow:hidden;clip:rect(1px,1px,1px,1px);white-space:nowrap}
.tf-skip{position:absolute;left:-999px;top:0;background:var(--tf-coral);color:#fff;padding:10px 16px;border-radius:0 0 8px 0;z-index:200}
.tf-skip:focus{left:0}

/* Reading progress */
.tf-progress{position:fixed;top:0;left:0;height:3px;width:0;background:var(--tf-coral);z-index:120;transition:width .1s linear}

/* Header */
.tf-header{position:sticky;top:0;z-index:110;background:rgba(251,247,240,0.92);backdrop-filter:saturate(140%) blur(6px);border-bottom:0.5px solid var(--tf-line)}
.tf-header-inner{display:flex;align-items:center;justify-content:space-between;gap:18px;height:66px}
.tf-brand{display:flex;align-items:center;gap:9px;flex:none}
.tf-brand a{display:flex;align-items:center;gap:9px;color:var(--tf-ink);text-decoration:none}
.tf-brand .ti{font-size:24px;color:var(--tf-coral)}
.tf-brand-name{font-family:var(--tf-font-display);font-weight:800;font-size:21px;letter-spacing:-0.01em}
.tf-nav{display:flex;align-items:center;gap:24px}
.tf-nav ul{list-style:none;display:flex;gap:22px;margin:0;padding:0}
.tf-nav a{color:var(--tf-ink);font-weight:500;font-size:15px;text-decoration:none}
.tf-nav a:hover{color:var(--tf-coral)}
.tf-header-tools{display:flex;align-items:center;gap:16px;flex:none}
.tf-icon-btn{background:none;border:none;cursor:pointer;color:var(--tf-ink);display:flex;align-items:center;padding:6px}
.tf-icon-btn .ti{font-size:21px}

/* Compass in the menu bar */
.tf-compass{position:relative;width:36px;height:36px;border-radius:50%;border:2px solid var(--tf-night);background:#10201C;flex:none}
.tf-compass .pt{position:absolute;font-size:8px;line-height:1;color:#8FA79D;font-weight:500}
.tf-compass .pt-n{top:2px;left:50%;transform:translateX(-50%)}
.tf-compass .pt-s{bottom:2px;left:50%;transform:translateX(-50%)}
.tf-compass .pt-w{left:3px;top:50%;transform:translateY(-50%)}
.tf-compass .pt-e{right:3px;top:50%;transform:translateY(-50%)}
.tf-needle{position:absolute;left:50%;top:50%;width:3px;height:22px;transform-origin:50% 50%;transform:translate(-50%,-50%)}
.tf-needle .nh{height:50%}
.tf-needle .nh-n{background:var(--tf-coral);border-radius:2px 2px 0 0}
.tf-needle .nh-s{background:#6E8278;border-radius:0 0 2px 2px}
.tf-compass .hub{position:absolute;left:50%;top:50%;width:6px;height:6px;border-radius:50%;background:#fff;transform:translate(-50%,-50%)}

/* Search toggle panel */
.tf-search-panel{display:none;border-top:0.5px solid var(--tf-line);background:var(--tf-bg)}
.tf-search-panel.open{display:block}
.tf-search-panel .tf-wrap{padding-top:16px;padding-bottom:16px}

/* Hero */
.tf-hero{position:relative;min-height:430px;display:flex;align-items:center;justify-content:center;text-align:center;color:#fff;overflow:hidden;background:#11808A}
.tf-hero-media{position:absolute;inset:-40px 0;background-size:cover;background-position:center}
.tf-hero-veil{position:absolute;inset:0;background:rgba(15,40,42,0.34)}
.tf-hero-inner{position:relative;max-width:640px;padding:60px 22px}
.tf-hero-kicker{display:inline-block;background:var(--tf-coral);color:#fff;font-size:12px;font-weight:500;letter-spacing:0.04em;text-transform:uppercase;padding:5px 13px;border-radius:999px}
.tf-hero h1{font-family:var(--tf-font-display);font-weight:800;font-size:clamp(30px,5vw,46px);margin:16px 0 0;color:#fff}
.tf-hero p{font-size:16px;color:rgba(255,255,255,0.92);margin:14px auto 0;max-width:460px}
.tf-hero-arc{position:absolute;top:40px;right:8%;width:170px;opacity:0.5}
.tf-hero-plane{position:absolute;top:34px;right:7%;font-size:22px;color:#fff;opacity:0.85;transform:rotate(38deg)}

/* Search form */
.tf-searchform{display:flex;align-items:center;gap:10px;background:#fff;border-radius:999px;padding:6px 6px 6px 18px;max-width:460px;margin:22px auto 0}
.tf-searchform .ti{font-size:18px;color:var(--tf-ink2)}
.tf-searchform input[type=search]{flex:1;border:none;outline:none;font-family:var(--tf-font-body);font-size:15px;color:var(--tf-ink);background:none;min-width:0}
.tf-searchform input[type=search]::placeholder{color:#9A958C}
.tf-searchform button{font-family:var(--tf-font-display);background:var(--tf-coral);color:#fff;font-weight:700;font-size:14px;padding:10px 22px;border:none;border-radius:999px;cursor:pointer}
.tf-searchform button:hover{background:var(--tf-coral-ink)}

/* Section heads */
.tf-section{padding:42px 0 6px}
.tf-section-head{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:18px}
.tf-section-head h2{font-family:var(--tf-font-display);font-weight:700;font-size:23px;margin:0}
.tf-section-head a{font-size:14px;font-weight:500;color:var(--tf-coral-ink)}

/* Destination tiles */
.tf-tiles{display:grid;grid-template-columns:repeat(5,1fr);gap:14px}
.tf-tile{position:relative;border-radius:var(--tf-radius);overflow:hidden;min-height:130px;display:flex;align-items:flex-end;padding:13px;color:#fff;text-decoration:none;background-size:cover;background-position:center}
.tf-tile .veil{position:absolute;inset:0;background:rgba(20,18,14,0.26);transition:background .3s}
.tf-tile:hover .veil{background:rgba(20,18,14,0.42)}
.tf-tile span{position:relative;font-family:var(--tf-font-display);font-weight:700;font-size:16px}

/* Card grid */
.tf-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.tf-card{display:flex;flex-direction:column}
.tf-card-media{display:block;text-decoration:none}
.tf-card .thumb{display:block;position:relative;height:188px;border-radius:var(--tf-radius);overflow:hidden;background-size:cover;background-position:center;background-color:var(--tf-teal)}
.tf-card .thumb .veil{position:absolute;inset:0;background:rgba(20,18,14,0.10)}
.tf-card .pill{position:absolute;top:12px;left:12px;background:#fff;color:var(--tf-ink);font-size:11px;font-weight:500;letter-spacing:0.03em;text-transform:uppercase;padding:4px 11px;border-radius:999px}
.tf-card h3{font-family:var(--tf-font-display);font-weight:700;font-size:18px;line-height:1.18;margin:13px 0 0}
.tf-card h3 a{color:var(--tf-ink);text-decoration:none}
.tf-card h3 a:hover{color:var(--tf-coral-ink)}
.tf-meta{display:flex;align-items:center;gap:9px;margin-top:11px;font-size:13px;color:var(--tf-ink2)}
.tf-avatar{width:26px;height:26px;border-radius:50%;background:#E7B7A6;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:500;color:#8A4A33;overflow:hidden}
.tf-avatar img{width:100%;height:100%}

/* Newsletter band */
.tf-news{background:var(--tf-coral);color:#fff;margin-top:48px}
.tf-news .tf-wrap{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;padding-top:26px;padding-bottom:26px}
.tf-news h2{font-family:var(--tf-font-display);font-weight:800;font-size:22px;margin:0;color:#fff}
.tf-news p{margin:5px 0 0;color:rgba(255,255,255,0.9);font-size:14px}
.tf-news form{display:flex;gap:8px}
.tf-news input[type=email]{border:none;border-radius:999px;padding:11px 18px;font-family:var(--tf-font-body);font-size:14px;min-width:220px}
.tf-news button{font-family:var(--tf-font-display);background:#fff;color:var(--tf-coral-ink);font-weight:700;border:none;border-radius:999px;padding:11px 22px;cursor:pointer}

/* Single article layout */
.tf-single{padding:34px 0 10px}
.tf-single-grid{display:grid;grid-template-columns:minmax(0,1fr) 256px;gap:42px;align-items:start}
.tf-article-hero{position:relative;height:330px;border-radius:16px;overflow:hidden;background-size:cover;background-position:center;background-color:#2E7D4F}
.tf-article-hero .veil{position:absolute;inset:0;background:rgba(18,34,22,0.22)}
.tf-article-hero .pill{position:absolute;top:15px;left:15px;background:var(--tf-coral);color:#fff;font-size:12px;font-weight:500;text-transform:uppercase;letter-spacing:0.03em;padding:5px 13px;border-radius:999px}
.tf-article-title{font-family:var(--tf-font-display);font-weight:800;font-size:clamp(26px,4vw,38px);margin:22px 0 0;line-height:1.05}
.tf-article-meta{display:flex;align-items:center;gap:10px;margin-top:16px;font-size:14px;color:var(--tf-ink2)}
.tf-article-meta .tf-avatar{width:32px;height:32px}

.entry-content{margin-top:26px;font-size:17px;color:var(--tf-ink-soft)}
.entry-content > h2{font-family:var(--tf-font-display);font-weight:700;font-size:24px;color:var(--tf-ink);margin:34px 0 12px;scroll-margin-top:90px}
.entry-content > h3{font-family:var(--tf-font-display);font-weight:700;font-size:19px;color:var(--tf-ink);margin:26px 0 10px;scroll-margin-top:90px}
.entry-content p{margin:0 0 16px}
.entry-content img,.entry-content figure{border-radius:var(--tf-radius)}
.entry-content figure{margin:22px 0}
.entry-content blockquote{border-left:3px solid var(--tf-coral);margin:24px 0;padding:2px 0 2px 18px}
.entry-content blockquote p{font-family:var(--tf-font-display);font-weight:500;font-size:21px;line-height:1.32;color:var(--tf-ink)}
.entry-content a{text-decoration:underline;text-underline-offset:2px}

/* Sidebar */
.tf-sidebar{position:sticky;top:90px;display:flex;flex-direction:column;gap:18px}
.tf-widget{background:var(--tf-surface);border:0.5px solid var(--tf-line);border-radius:var(--tf-radius);padding:16px 17px}
.tf-widget-title{font-family:var(--tf-font-display);font-weight:700;font-size:15px;margin:0 0 9px}
.tf-toc{list-style:none;margin:0;padding:0}
.tf-toc li{margin:0}
.tf-toc a{display:flex;align-items:center;gap:9px;font-size:13.5px;color:var(--tf-ink2);padding:6px 0;text-decoration:none}
.tf-toc a .dot{width:6px;height:6px;border-radius:50%;background:#D8CFBF;flex:none;transition:transform .2s,background .2s}
.tf-toc a:hover{color:var(--tf-ink)}
.tf-toc a.is-active{color:var(--tf-coral-ink);font-weight:500}
.tf-toc a.is-active .dot{background:var(--tf-coral);transform:scale(1.5)}
.tf-related{display:flex;flex-direction:column;gap:13px}
.tf-related-item{display:flex;gap:11px;align-items:center;text-decoration:none}
.tf-related-thumb{width:48px;height:48px;border-radius:9px;flex:none;background-size:cover;background-position:center;background-color:var(--tf-teal)}
.tf-related-cat{font-size:10px;color:var(--tf-coral-ink);font-weight:500;letter-spacing:0.04em;text-transform:uppercase}
.tf-related-item h4{font-size:12.5px;line-height:1.3;font-weight:500;margin:2px 0 0;color:var(--tf-ink)}

/* Reveal on scroll */
.tf-reveal{opacity:0;transform:translateY(22px);transition:opacity .6s ease,transform .6s ease}
.tf-reveal.is-in{opacity:1;transform:none}

/* Footer */
.tf-footer{background:var(--tf-night);color:#CFE0D8;margin-top:0;padding:46px 0 26px}
.tf-footer a{color:#CFE0D8}
.tf-footer-cols{display:flex;flex-wrap:wrap;gap:40px;justify-content:space-between}
.tf-footer .tf-brand-name{color:#fff}
.tf-footer .tf-brand .ti{color:var(--tf-coral)}
.tf-footer h4{font-family:var(--tf-font-display);font-weight:700;color:#fff;font-size:14px;margin:0 0 10px}
.tf-footer ul{list-style:none;margin:0;padding:0}
.tf-footer li{margin:0 0 7px;font-size:14px}
.tf-footer-bottom{border-top:1px solid rgba(255,255,255,0.12);margin-top:34px;padding-top:18px;font-size:13px;color:#9FB3AA;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px}

/* Posts page / archive */
.tf-page-head{padding:40px 0 6px}
.tf-page-head h1{font-family:var(--tf-font-display);font-weight:800;font-size:clamp(26px,4vw,38px);margin:0}
.tf-page-head p{color:var(--tf-ink2);margin:8px 0 0}
.tf-pagination{padding:30px 0 10px;display:flex;gap:8px;flex-wrap:wrap}
.tf-pagination .page-numbers{display:inline-flex;min-width:38px;height:38px;align-items:center;justify-content:center;border:0.5px solid var(--tf-line);border-radius:9px;color:var(--tf-ink);text-decoration:none;padding:0 10px}
.tf-pagination .page-numbers.current{background:var(--tf-coral);color:#fff;border-color:var(--tf-coral)}

.tf-mobile-toggle{display:none}

@media (max-width:980px){
  .tf-tiles{grid-template-columns:repeat(2,1fr)}
  .tf-grid{grid-template-columns:repeat(2,1fr)}
  .tf-single-grid{grid-template-columns:1fr;gap:30px}
  .tf-sidebar{position:static}
}
@media (max-width:680px){
  .tf-nav{position:absolute;top:66px;left:0;right:0;background:var(--tf-bg);border-bottom:0.5px solid var(--tf-line);flex-direction:column;align-items:flex-start;padding:14px 22px;display:none}
  .tf-nav.open{display:flex}
  .tf-nav ul{flex-direction:column;gap:14px}
  .tf-mobile-toggle{display:flex}
  .tf-grid{grid-template-columns:1fr}
  .tf-tiles{grid-template-columns:repeat(2,1fr)}
  .tf-compass{display:none}
}

@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  .tf-reveal{opacity:1!important;transform:none!important;transition:none}
  .tf-hero-media,.tf-article-hero{transform:none!important}
}
