/* =========================================================================
   TAD Theme — main stylesheet
   System fonts · CSS custom properties · mobile-first · no framework
   ========================================================================= */

:root{
	/* Brand: deep teal + terracotta accent + warm cream — refined & travel-premium */
	--brand:#0f6e64;--brand-deep:#0a4f48;--brand-700:#083b36;
	--ocean:#0f6e64;--ocean-deep:#0a4f48;--ocean-soft:#e6f2ef;
	--coral:#d9763e;--coral-deep:#bf6230;--coral-soft:#fbeede;
	--gold:#c79a4f;
	--ink:#13211e;--slate:#3e4d49;--mute:#6f7d79;
	--line:#e7ece9;--bg:#ffffff;--tint:#f6faf8;--sand:#fbf4ea;
	--radius:16px;--radius-sm:10px;--radius-lg:22px;
	--shadow:0 10px 30px rgba(12,50,44,.10);--shadow-sm:0 2px 10px rgba(12,50,44,.07);
	--container:1180px;--gap:24px;
	--font:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
}

/* Inline SVG icons inherit colour + align with text */
.tad-icon{display:inline-block;vertical-align:middle;flex:none}
.tad-social{display:block}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{margin:0;font-family:var(--font);color:var(--ink);background:var(--bg);line-height:1.6;font-size:17px}
img{max-width:100%;height:auto;display:block}
a{color:var(--ocean);text-decoration:none}
a:hover{color:var(--ocean-deep)}
h1,h2,h3,h4{line-height:1.2;font-weight:800;color:var(--ink);margin:0 0 .5em}
h1{font-size:clamp(1.8rem,4vw,2.6rem)}
h2{font-size:clamp(1.4rem,2.6vw,2rem)}
h3{font-size:1.2rem}
p{margin:0 0 1em}
.container{max-width:var(--container);margin-inline:auto;padding-inline:20px}
.screen-reader-text{position:absolute!important;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap}
.skip-link{position:absolute;left:-9999px}
.skip-link:focus{left:8px;top:8px;background:#fff;padding:8px 14px;border-radius:8px;z-index:1000}

/* Buttons ---------------------------------------------------------------- */
.btn,.search-form button,.hero__search button,.newsletter__form button,.destination-picker button{
	display:inline-flex;align-items:center;justify-content:center;gap:8px;
	background:var(--coral);color:#fff;border:0;border-radius:30px;
	padding:12px 24px;font-size:1rem;font-weight:700;cursor:pointer;transition:.15s;white-space:nowrap}
.btn:hover,.search-form button:hover,.hero__search button:hover,.newsletter__form button:hover{background:var(--coral-deep);color:#fff}
.btn--ghost{background:transparent;color:var(--ocean);border:2px solid var(--ocean)}
.btn--ghost:hover{background:var(--ocean);color:#fff}

/* Header ----------------------------------------------------------------- */
.site-header{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.88);backdrop-filter:saturate(180%) blur(12px);border-bottom:1px solid var(--line);transition:box-shadow .2s,height .2s}
/* Sit flush below the WP admin toolbar (logged-in users only) */
.admin-bar .site-header{top:32px}
@media screen and (max-width:782px){.admin-bar .site-header{top:46px}}
.site-header.is-stuck{box-shadow:0 4px 20px rgba(12,50,44,.08)}
.site-header__bar{display:flex;align-items:center;gap:20px;height:74px}
.site-header__brand{display:flex;align-items:center;gap:10px}
.site-logo{display:flex;align-items:center;gap:11px;color:var(--ink)}
.site-logo:hover{color:var(--ink)}
.brand-mark{flex:none;border-radius:50%;box-shadow:0 4px 12px rgba(15,110,100,.28)}
.brand-name{display:flex;flex-direction:column;line-height:1}
.brand-name strong{font-size:1.04rem;font-weight:800;letter-spacing:-.01em}
.brand-name span{font-size:.68rem;font-weight:700;letter-spacing:.28em;text-transform:uppercase;color:var(--coral);margin-top:3px}
.primary-nav{margin-left:auto}
.primary-nav__list{display:flex;gap:6px;list-style:none;margin:0;padding:0;align-items:center}
.primary-nav__list a{display:block;color:var(--ink);font-weight:600;font-size:.95rem;padding:8px 12px;border-radius:8px;transition:.15s}
.primary-nav__list a:hover{color:var(--brand);background:var(--ocean-soft)}
.primary-nav .current-menu-item>a{color:var(--brand)}
.site-header__actions{display:flex;align-items:center;gap:8px}
.icon-btn{position:relative;background:transparent;border:1px solid var(--line);border-radius:12px;width:42px;height:42px;cursor:pointer;color:var(--ink);display:inline-flex;align-items:center;justify-content:center;transition:.15s}
.icon-btn:hover{border-color:var(--brand);color:var(--brand);background:var(--ocean-soft)}
.icon-btn--saved:hover{color:var(--coral);border-color:var(--coral);background:var(--coral-soft)}
.wishlist-count{position:absolute;top:-6px;right:-6px;background:var(--coral);color:#fff;border-radius:20px;font-size:.66rem;font-weight:700;padding:1px 6px;min-width:18px;text-align:center;line-height:1.5;border:2px solid #fff}
.header-cta{padding:10px 18px}
.btn--sm{padding:9px 16px;font-size:.92rem}
@media(max-width:1080px){.header-cta{display:none}}
.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px}
.nav-toggle span{width:22px;height:2px;background:var(--ink);border-radius:2px;transition:.2s}

/* Search overlay --------------------------------------------------------- */
.search-overlay{border-top:1px solid var(--line);background:#fff;padding:18px 0}
.search-overlay .container{display:flex;gap:12px;align-items:center}
.search-form{display:flex;gap:8px;flex:1}
.search-form input,.search-overlay input[type=search]{flex:1;padding:12px 16px;border:1px solid var(--line);border-radius:30px;font-size:1rem}
.search-overlay__close{background:none;border:0;font-size:1.8rem;cursor:pointer;color:var(--mute);line-height:1}

/* Hero ------------------------------------------------------------------- */
.hero{position:relative;background:linear-gradient(140deg,var(--brand-deep) 0%,var(--brand) 58%,#15897c 100%);color:#fff;padding:76px 0 88px;overflow:hidden}
.hero__overlay{position:absolute;inset:0;background:radial-gradient(circle at 82% 18%,rgba(199,154,79,.22),transparent 42%),radial-gradient(circle at 8% 92%,rgba(255,255,255,.10),transparent 38%)}
.hero__inner{position:relative;text-align:center;max-width:760px}
.hero__eyebrow{text-transform:uppercase;letter-spacing:.18em;font-size:.78rem;font-weight:700;opacity:.85;margin:0 0 12px}
.hero__title{color:#fff;font-size:clamp(2rem,5vw,3.4rem);margin:0 0 12px}
.hero__sub{font-size:1.15rem;opacity:.92;margin:0 0 28px}
.hero__search{display:flex;gap:8px;background:#fff;padding:8px;border-radius:40px;box-shadow:var(--shadow);max-width:620px;margin:0 auto}
.hero__search input{flex:1;border:0;padding:12px 18px;font-size:1.02rem;border-radius:30px;color:var(--ink)}
.hero__search input:focus{outline:none}
.hero__chips{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;align-items:center;margin-top:20px;font-size:.92rem}
.hero__chips span{opacity:.8}
.hero__chips a{background:rgba(255,255,255,.16);color:#fff;padding:6px 14px;border-radius:30px;backdrop-filter:blur(4px)}
.hero__chips a:hover{background:rgba(255,255,255,.28)}

/* Sections --------------------------------------------------------------- */
.section{padding:56px 0}
.section--tint{background:var(--tint)}
.section__head{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:28px;flex-wrap:wrap}
.section__head--archive{flex-direction:column;align-items:flex-start}
.section__title{margin:0}
.section__sub{color:var(--mute);margin:6px 0 0}
.section__link{font-weight:700;white-space:nowrap}

/* Card grid -------------------------------------------------------------- */
.grid{display:grid;gap:var(--gap)}
.grid--cards{grid-template-columns:repeat(auto-fill,minmax(230px,1fr))}
.card{display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);transition:transform .15s,box-shadow .15s;color:var(--ink)}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow);color:var(--ink)}
.card__media{position:relative;aspect-ratio:3/2;background:linear-gradient(135deg,var(--ocean-soft),var(--sand));overflow:hidden}
.card__media img{width:100%;height:100%;object-fit:cover}
.card__placeholder{position:absolute;inset:0;display:grid;place-items:center;color:var(--brand);opacity:.45}
.card__badge{position:absolute;top:10px;left:10px;display:inline-flex;align-items:center;gap:4px;background:var(--coral);color:#fff;font-size:.66rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;padding:4px 9px;border-radius:6px}
.card__body{padding:14px 16px;display:flex;flex-direction:column;gap:3px}
.card__eyebrow{font-size:.7rem;text-transform:uppercase;letter-spacing:.06em;color:var(--coral);font-weight:700}
.card__title{font-weight:700;font-size:1.02rem;line-height:1.3}
.card__meta{font-size:.82rem;color:var(--mute)}

/* Silos ------------------------------------------------------------------ */
.silos{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:16px}
.silo{display:flex;flex-direction:column;align-items:center;gap:12px;text-align:center;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:26px 14px;font-weight:700;color:var(--ink);transition:.15s}
.silo:hover{border-color:var(--brand);color:var(--brand);transform:translateY(-3px);box-shadow:var(--shadow-sm)}
.silo__icon{display:grid;place-items:center;width:56px;height:56px;border-radius:16px;background:var(--ocean-soft);color:var(--brand);transition:.15s}
.silo:hover .silo__icon{background:var(--brand);color:#fff}
.silo__name{font-size:.98rem}

/* Tools ------------------------------------------------------------------ */
.tools{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:var(--gap)}
.tool{display:flex;flex-direction:column;gap:10px;background:linear-gradient(160deg,#fff,var(--ocean-soft));border:1px solid var(--line);border-radius:var(--radius-lg);padding:28px 26px;color:var(--ink);transition:.15s}
.tool:hover{transform:translateY(-4px);box-shadow:var(--shadow);color:var(--ink)}
.tool:hover .tool__cta{gap:10px}
.tool__icon{display:grid;place-items:center;width:54px;height:54px;border-radius:14px;background:#fff;color:var(--brand);box-shadow:var(--shadow-sm)}
.tool__title{font-weight:800;font-size:1.2rem}
.tool__desc{color:var(--slate);font-size:.95rem;flex:1}
.tool__cta{display:inline-flex;align-items:center;gap:6px;color:var(--coral);font-weight:700;font-size:.92rem;margin-top:4px;transition:gap .15s}

/* Single hero ------------------------------------------------------------ */
.single__hero{position:relative;min-height:340px;display:flex;align-items:flex-end;background:linear-gradient(135deg,var(--ocean-deep),var(--ocean));overflow:hidden}
.single__hero--compact{min-height:240px}
.single__hero-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.single__hero-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(8,20,40,.78),rgba(8,20,40,.15) 60%,transparent)}
.single__hero-inner{position:relative;color:#fff;padding-block:28px 32px;width:100%}
/* Breadcrumbs sit on the dark hero image — override the plugin's light-bg colors */
.single__hero .tad-breadcrumbs{color:rgba(255,255,255,.85);text-shadow:0 1px 3px rgba(0,0,0,.45)}
.single__hero .tad-breadcrumbs a{color:#fff;text-decoration:none}
.single__hero .tad-breadcrumbs a:hover{text-decoration:underline}
.single__hero .tad-breadcrumbs .sep{color:rgba(255,255,255,.6)}
.single__title{color:#fff;margin:.2em 0}
.single__lede{color:rgba(255,255,255,.92);font-size:1.1rem;max-width:680px;margin:0}
.single__meta{color:rgba(255,255,255,.85);font-size:.9rem}

/* Single layout ---------------------------------------------------------- */
.single__layout{display:grid;grid-template-columns:1fr;gap:40px;padding-block:40px}
@media(min-width:980px){.single__layout{grid-template-columns:minmax(0,1fr) 320px}}
.single--destination .container,.single--page .container{padding-block:40px}
.block{margin:40px 0}
.block--tool{background:var(--tint);border:1px solid var(--line);border-radius:var(--radius-lg);padding:28px}
.tools-embed{display:grid;gap:24px;margin:40px 0}
@media(min-width:880px){.tools-embed{grid-template-columns:1fr 1fr}}

/* Byline (E-E-A-T trust signals) ---------------------------------------- */
.single__byline{display:flex;flex-wrap:wrap;align-items:center;gap:14px;color:var(--mute);font-size:.9rem;margin:0 0 22px;padding-bottom:16px;border-bottom:1px solid var(--line)}
.single__byline-item{display:inline-flex;align-items:center;gap:6px}
.single__byline-item svg{color:var(--brand)}
.single__byline-avatar{border-radius:50%;width:40px;height:40px}
.single__byline-author{display:flex;flex-direction:column;line-height:1.25;font-weight:700;color:var(--ink)}
.single__byline-author a{color:var(--ink)}
.single__byline-author a:hover{color:var(--brand)}
.single__byline-role{font-weight:400;font-size:.8rem;color:var(--mute)}
.single--destination .single__byline,.single--page .single__byline{margin-top:8px}

/* Author archive -------------------------------------------------------- */
.author-page{padding-block:48px}
.author-hero{display:flex;gap:22px;align-items:flex-start;background:linear-gradient(160deg,#fff,var(--ocean-soft));border:1px solid var(--line);border-radius:var(--radius-lg);padding:28px;margin-bottom:36px}
.author-hero__avatar{border-radius:50%;width:104px;height:104px;flex:0 0 auto;box-shadow:var(--shadow-sm)}
.author-hero__kicker{margin:0;font-size:.74rem;text-transform:uppercase;letter-spacing:.05em;color:var(--brand);font-weight:700}
.author-hero__name{margin:.1em 0 .1em}
.author-hero__role{margin:0 0 8px;color:var(--coral-deep,#bf6230);font-weight:600}
.author-hero__bio{margin:0 0 12px;color:var(--slate);max-width:70ch}
.author-hero__social{display:flex;gap:10px}
.author-hero__social a{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border:1px solid var(--line);border-radius:50%;color:var(--slate);transition:.15s}
.author-hero__social a:hover{background:var(--brand);border-color:var(--brand);color:#fff}
@media(max-width:640px){.author-hero{flex-direction:column;align-items:center;text-align:center}.author-hero__bio{text-align:left}}

/* Table of contents ----------------------------------------------------- */
.tad-toc{background:var(--tint,#f6faf8);border:1px solid var(--line);border-radius:var(--radius);padding:18px 22px;margin:0 0 28px}
.tad-toc__title{font-size:.8rem;text-transform:uppercase;letter-spacing:.05em;color:var(--mute);margin:0 0 10px}
.tad-toc__list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:6px}
.tad-toc__item--h3{padding-left:18px;font-size:.95rem}
.tad-toc__item a{color:var(--slate);text-decoration:none;border-bottom:1px solid transparent}
.tad-toc__item a:hover{color:var(--brand);border-bottom-color:var(--brand)}
.prose :where(h2,h3){scroll-margin-top:90px}

/* Share / copy-link ----------------------------------------------------- */
.tad-share{display:flex;flex-wrap:wrap;align-items:center;gap:10px;margin:28px 0;padding:16px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.tad-share__label{font-weight:700;color:var(--ink);margin-right:4px}
.tad-share__btn{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:50%;border:1px solid var(--line);background:#fff;color:var(--slate);cursor:pointer;transition:.15s;position:relative}
.tad-share__btn:hover{color:#fff;transform:translateY(-2px)}
.tad-share__btn--x:hover{background:#111;border-color:#111}
.tad-share__btn--facebook:hover{background:#1877f2;border-color:#1877f2}
.tad-share__btn--pinterest:hover{background:#e60023;border-color:#e60023}
.tad-share__btn--whatsapp:hover{background:#25d366;border-color:#25d366}
.tad-share__btn--email:hover{background:var(--brand);border-color:var(--brand)}
.tad-share__btn--copy:hover{background:var(--coral);border-color:var(--coral);color:#fff}
.tad-share__copied{position:absolute;bottom:-26px;left:50%;transform:translateX(-50%);background:var(--ink);color:#fff;font-size:.72rem;padding:3px 8px;border-radius:6px;white-space:nowrap}
.tad-share__copied:empty{display:none}
.tad-share__btn--embed:hover{background:var(--brand);border-color:var(--brand);color:#fff}
.tad-embed-box{margin:0 0 28px;padding:16px;border:1px solid var(--line);border-radius:var(--radius);background:var(--tint,#f6faf8)}
.tad-embed-box__title{margin:0 0 8px;font-weight:700;font-size:.92rem}
.tad-embed-box__title span{font-weight:400;color:var(--mute)}
.tad-embed-type{display:block;margin:0 0 10px;padding:8px 10px;border:1px solid var(--line);border-radius:8px;font-size:.9rem;background:#fff;color:var(--ink)}
.tad-embed-box__code{width:100%;font:13px/1.5 ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;padding:10px;border:1px solid var(--line);border-radius:10px;background:#fff;color:var(--ink);resize:vertical}
.tad-embed-box .btn--sm{margin-top:10px}

/* Prose ------------------------------------------------------------------ */
.prose{font-size:1.06rem;color:#1e293b}
.prose--narrow{max-width:760px}
.prose h2{margin-top:1.6em}
.prose h3{margin-top:1.3em}
.prose img{border-radius:var(--radius);margin:1.2em 0}
.prose ul,.prose ol{padding-left:1.3em}
.prose a{text-decoration:underline;text-underline-offset:2px}
.prose blockquote{margin:1.4em 0;padding:.6em 1.2em;border-left:4px solid var(--ocean);background:var(--ocean-soft);border-radius:0 10px 10px 0}

/* Quickfacts ------------------------------------------------------------- */
.quickfacts{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:14px;margin:8px 0 28px}
.quickfacts__item{display:flex;align-items:center;gap:12px;background:#fff;border:1px solid var(--line);border-radius:var(--radius-sm);padding:14px 16px;box-shadow:var(--shadow-sm)}
.quickfacts__icon{display:grid;place-items:center;width:38px;height:38px;border-radius:10px;background:var(--ocean-soft);color:var(--brand);flex:none}
.quickfacts__text{display:flex;flex-direction:column;min-width:0}
.quickfacts__label{font-size:.7rem;text-transform:uppercase;letter-spacing:.04em;color:var(--mute);margin-bottom:2px}
.quickfacts__item strong{font-size:1rem;line-height:1.25}

/* Guide links ------------------------------------------------------------ */
.guide-links{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:12px}
.guide-link{display:flex;align-items:center;justify-content:space-between;gap:10px;background:#fff;border:1px solid var(--line);border-radius:var(--radius-sm);padding:14px 18px;font-weight:700;color:var(--ink);transition:.15s}
.guide-link:hover{border-color:var(--ocean);color:var(--ocean);transform:translateX(3px)}
.guide-link__arrow{color:var(--coral)}

/* Sidebar ---------------------------------------------------------------- */
.sidebar{display:flex;flex-direction:column;gap:24px}
.sidebar__card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow-sm)}
.sidebar__card h2,.sidebar__card h3{margin-top:0;font-size:1.05rem}
.sidebar__save{background:linear-gradient(160deg,var(--sand),#fff)}
@media(min-width:980px){.sidebar{position:sticky;top:88px;align-self:start}}

/* Newsletter ------------------------------------------------------------- */
.newsletter{position:relative;background:linear-gradient(135deg,var(--brand) 0%,var(--brand-deep) 100%);color:#fff;padding:52px 0;overflow:hidden}
.newsletter::after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 88% 30%,rgba(199,154,79,.25),transparent 45%);pointer-events:none}
.newsletter__inner{position:relative;display:flex;align-items:center;justify-content:space-between;gap:28px;flex-wrap:wrap}
.newsletter__copy{display:flex;align-items:center;gap:16px}
.newsletter__icon{display:grid;place-items:center;width:54px;height:54px;border-radius:14px;background:rgba(255,255,255,.14);color:#fff;flex:none}
.newsletter__title{color:#fff;margin:0 0 4px}
.newsletter__sub{margin:0;opacity:.9}
.newsletter__form{display:flex;gap:8px;background:#fff;padding:6px;border-radius:40px;min-width:300px;flex:1;max-width:440px}
.newsletter__form input{flex:1;border:0;padding:12px 18px;border-radius:30px;font-size:1rem;color:var(--ink)}
.newsletter__form input:focus{outline:none}

/* Footer ----------------------------------------------------------------- */
.site-footer{background:#0e1c1a;color:#b4c3bf;padding:56px 0 26px;font-size:.94rem}
.site-footer__grid{display:grid;grid-template-columns:1.6fr repeat(3,1fr);gap:36px;padding-bottom:32px;border-bottom:1px solid rgba(255,255,255,.08)}
.site-footer .site-logo{color:#fff}
.site-footer .brand-name strong{color:#fff}
.site-footer .brand-mark{box-shadow:none}
.site-footer__blurb{margin:14px 0 18px;max-width:340px;color:#9fb0ac;line-height:1.6}
.social{display:flex;gap:10px}
.social__link{display:grid;place-items:center;width:38px;height:38px;border-radius:10px;background:rgba(255,255,255,.06);color:#cdd9d6;transition:.15s}
.social__link:hover{background:var(--brand);color:#fff;transform:translateY(-2px)}
.footer-col__title,.footer-widget__title{color:#fff;font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;margin:0 0 14px}
.site-footer ul,.footer-menu{list-style:none;margin:0;padding:0}
.site-footer li{margin:9px 0}
.site-footer li a{display:inline-flex;align-items:center;gap:8px;color:#b4c3bf}
.site-footer li a .tad-icon{color:var(--gold);opacity:.85}
.site-footer a:hover{color:#fff}
.site-footer__bottom{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;padding-top:22px;color:#7f918d;font-size:.85rem}
.site-footer__bottom p{margin:0}
.site-footer__legal{display:flex;gap:18px}
.site-footer__legal a{color:#9fb0ac}
@media(max-width:760px){.site-footer__grid{grid-template-columns:1fr 1fr}.site-footer__brand{grid-column:1/-1}}

/* Tool pages ------------------------------------------------------------- */
.tool-page{padding-block:48px;max-width:860px}
.tool-page__head{text-align:center;margin-bottom:32px}
.destination-picker{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;background:var(--tint);padding:24px;border-radius:var(--radius)}
.destination-picker select{padding:12px;border:1px solid var(--line);border-radius:10px;font-size:1rem;min-width:240px}
.tool-page__aside{margin-top:28px}
.tool-page__cta{text-align:center;margin-top:28px}
.destination-picker button{flex:0 0 auto}
/* Two-column tool layout (calculator + sidebar) */
.tool-page:has(.tool-page__grid){max-width:1080px}
.tool-page__grid{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:28px;align-items:start}
.tool-page__grid .tool-page__aside{margin-top:0}
.tool-note{background:var(--tint,#f6faf8);border:1px solid var(--line);border-radius:var(--radius);padding:20px;margin-top:20px}
.tool-note h3{margin:0 0 10px;font-size:1.05rem}
.tool-note ul{margin:0 0 10px;padding-left:18px;color:var(--slate);font-size:.92rem;line-height:1.6}
.tool-note__fine{font-size:.8rem;color:var(--mute);margin:0}
.tool-empty{text-align:center;background:var(--tint,#f6faf8);border:1px dashed var(--line);border-radius:var(--radius);padding:40px 24px}
.tool-empty p{color:var(--slate);margin:0 0 18px}
@media(max-width:820px){.tool-page__grid{grid-template-columns:1fr}}

/* Archive / pagination / 404 -------------------------------------------- */
.archive{padding-block:48px}
.pagination{display:flex;gap:8px;justify-content:center;margin-top:36px;flex-wrap:wrap}
.pagination .page-numbers{padding:8px 14px;border:1px solid var(--line);border-radius:10px;color:var(--ink)}
.pagination .current{background:var(--ocean);color:#fff;border-color:var(--ocean)}
.error-404{text-align:center;padding-block:64px}
.error-404__code{font-size:5rem;color:var(--ocean);margin:0}
.error-404__msg{font-size:1.2rem;color:var(--slate);margin-bottom:24px}
.error-404 .search-form{max-width:480px;margin:0 auto 1rem}
.notice{background:var(--ocean-soft);border:1px solid #a5f3fc;border-radius:var(--radius);padding:20px;color:var(--ocean-deep)}
.page-head{padding-top:40px}

/* Mobile nav ------------------------------------------------------------- */
@media(max-width:860px){
	.nav-toggle{display:flex}
	.primary-nav{position:fixed;inset:74px 0 auto 0;background:#fff;border-bottom:1px solid var(--line);transform:translateY(-120%);transition:transform .25s;box-shadow:var(--shadow);margin:0}
	.primary-nav.is-open{transform:translateY(0)}
	.primary-nav__list{flex-direction:column;align-items:stretch;gap:0;padding:8px 20px}
	.primary-nav__list li{border-bottom:1px solid var(--line)}
	.primary-nav__list a{display:block;padding:14px 0}
	.nav-toggle[aria-expanded=true] span:nth-child(1){transform:translateY(6px) rotate(45deg)}
	.nav-toggle[aria-expanded=true] span:nth-child(2){opacity:0}
	.nav-toggle[aria-expanded=true] span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}
}

@media(prefers-reduced-motion:reduce){*{scroll-behavior:auto!important;transition:none!important;animation:none!important}}
