/*
Theme Name: SkiBro
Theme URI: https://www.skibro.com/
Author: SkiBro Editorial
Description: Custom theme for skibro.com — worldwide ski-resort directory & ski guides. Faithful magenta/plum relaunch.
Version: 1.0.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: skibro
Tags: custom-menu, featured-images, translation-ready, custom-post-types
*/

/* ============ Fonts (self-hosted) ============ */
@font-face{font-family:'Poppins';font-style:normal;font-weight:300;font-display:swap;src:url('assets/fonts/poppins-300.woff2') format('woff2');}
@font-face{font-family:'Poppins';font-style:normal;font-weight:400;font-display:swap;src:url('assets/fonts/poppins-400.woff2') format('woff2');}
@font-face{font-family:'Poppins';font-style:normal;font-weight:600;font-display:swap;src:url('assets/fonts/poppins-600.woff2') format('woff2');}
@font-face{font-family:'Poppins';font-style:normal;font-weight:800;font-display:swap;src:url('assets/fonts/poppins-800.woff2') format('woff2');}
@font-face{font-family:'Poppins';font-style:normal;font-weight:900;font-display:swap;src:url('assets/fonts/poppins-900.woff2') format('woff2');}
@font-face{font-family:'Albert Sans';font-style:normal;font-weight:400;font-display:swap;src:url('assets/fonts/albert-sans-400.woff2') format('woff2');}
@font-face{font-family:'Albert Sans';font-style:normal;font-weight:500;font-display:swap;src:url('assets/fonts/albert-sans-500.woff2') format('woff2');}
@font-face{font-family:'Albert Sans';font-style:normal;font-weight:600;font-display:swap;src:url('assets/fonts/albert-sans-600.woff2') format('woff2');}

/* ============ Tokens ============ */
:root{
  --primary:#F61F84; --primary-hover:#EE2553;
  --plum-dark:#322838; --plum-main:#533043; --plum-muted:#785766;
  --bg-warm:#FFFCF9; --bg-pink:#FFE5F1; --pink-50:#FFF3F8; --pink-100:#FFE0EE;
  --neutral:#767676; --neutral-2:#616161; --line:#F1D9E5; --grey-50:#F7F5F6;
  --radius:18px; --radius-lg:32px; --radius-pill:999px;
  --shadow-card:0 10px 30px -10px rgba(83,48,67,.10);
  --shadow-hover:0 20px 40px -15px rgba(83,48,67,.18);
  --maxw:1200px; --gap:2rem;
}
*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{margin:0;font-family:'Albert Sans',system-ui,sans-serif;background:var(--bg-warm);color:var(--plum-main);font-size:17px;line-height:1.6;-webkit-font-smoothing:antialiased;}
h1,h2,h3,h4,h5,.skb-display{font-family:'Poppins',sans-serif;color:var(--plum-dark);line-height:1.15;margin:0 0 .5em;}
h1{font-size:clamp(2.2rem,4vw,3.6rem);font-weight:900;letter-spacing:-.02em;overflow-wrap:break-word;word-break:break-word;hyphens:auto;}
h2,h3{overflow-wrap:break-word;}
h2{font-size:clamp(1.8rem,3vw,2.5rem);font-weight:800;letter-spacing:-.01em;}
h3{font-size:1.5rem;font-weight:700;}
a{color:inherit;text-decoration:none;}
img{max-width:100%;display:block;}
p{margin:0 0 1rem;}
.skb-wrap{max-width:var(--maxw);margin:0 auto;padding:0 1.5rem;}
.skb-muted{color:var(--plum-muted);}
.skb-section{padding:5rem 0;}
.skb-eyebrow{color:var(--primary);font-weight:700;font-size:.78rem;text-transform:uppercase;letter-spacing:.12em;}
.skb-icon{display:inline-block;width:1em;height:1em;vertical-align:-.125em;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;}

/* ============ Buttons ============ */
.skb-btn{display:inline-flex;align-items:center;gap:.5rem;background:var(--primary);color:#fff;border:none;cursor:pointer;
  padding:.85rem 1.75rem;border-radius:var(--radius-pill);font-family:'Albert Sans',sans-serif;font-weight:600;font-size:1rem;
  transition:background .2s,transform .2s;box-shadow:0 8px 20px -8px rgba(246,31,132,.5);}
.skb-btn:hover{background:var(--primary-hover);transform:translateY(-1px);}
.skb-btn--lg{padding:1.05rem 2.5rem;font-size:1.1rem;font-weight:700;}
.skb-btn--ghost{background:transparent;color:var(--primary);box-shadow:none;border:2px solid var(--pink-100);}
.skb-btn--ghost:hover{background:var(--pink-50);}
.skb-link-arrow{color:var(--primary);font-weight:700;display:inline-flex;align-items:center;gap:.4rem;}
.skb-link-arrow:hover{text-decoration:underline;}

/* ============ Header ============ */
.skb-header{position:sticky;top:0;z-index:50;background:rgba(255,252,249,.92);backdrop-filter:blur(8px);border-bottom:1px solid var(--pink-100);}
.skb-header__inner{display:flex;align-items:center;justify-content:space-between;height:5rem;}
.skb-logo{display:flex;align-items:center;gap:.65rem;}
.skb-logo svg{height:1.9rem;width:auto;}
.skb-logo__word{font-family:'Poppins',sans-serif;font-size:1.5rem;letter-spacing:-.04em;color:var(--plum-dark);}
.skb-logo__word b{font-weight:900;}.skb-logo__word span{font-weight:300;}
.skb-nav{display:flex;align-items:center;gap:2rem;}
.skb-nav a{font-weight:500;font-size:.95rem;color:var(--plum-main);transition:color .2s;}
.skb-nav a:hover,.skb-nav .current-menu-item>a{color:var(--primary);}
.skb-header__actions{display:flex;align-items:center;gap:1.5rem;}
.skb-langs{display:flex;align-items:center;gap:.6rem;font-size:.85rem;font-weight:600;color:var(--plum-muted);}
.skb-langs a.is-active{color:var(--plum-dark);}
.skb-langs a:hover{color:var(--primary);}
.skb-langs .sep{color:#e6cdd9;}
.skb-burger{display:none;background:none;border:none;color:var(--plum-dark);cursor:pointer;padding:.3rem;}
.skb-burger svg{width:1.7rem;height:1.7rem;}

/* ============ Hero ============ */
.skb-hero{background:linear-gradient(135deg,#FFFCF9 0%,#FFE5F1 100%);padding:7rem 0 6rem;position:relative;overflow:hidden;text-align:center;}
.skb-hero__inner{max-width:880px;margin:0 auto;position:relative;z-index:2;}
.skb-hero p{font-size:1.2rem;color:var(--plum-muted);max-width:620px;margin:1.2rem auto 2.5rem;font-weight:500;}
.skb-search{display:flex;align-items:center;background:#fff;border:1px solid var(--pink-100);border-radius:var(--radius-pill);
  padding:.5rem;max-width:640px;margin:0 auto;box-shadow:0 24px 60px -25px rgba(83,48,67,.25);}
.skb-search__field{flex:1;display:flex;align-items:center;gap:.7rem;padding:0 1.25rem;color:var(--plum-muted);}
.skb-search input{flex:1;border:none;outline:none;background:none;font-family:inherit;font-size:1.05rem;padding:.9rem 0;color:var(--plum-main);}
.skb-search .skb-icon{font-size:1.4rem;}
.skb-hero__deco{position:absolute;opacity:.08;color:var(--primary);z-index:1;}
.skb-hero__deco--1{top:30%;left:3%;width:120px;height:120px;}
.skb-hero__deco--2{top:22%;right:4%;width:90px;height:90px;}

/* ============ Section heads ============ */
.skb-sechead{display:flex;align-items:flex-end;justify-content:space-between;gap:1rem;margin-bottom:3rem;flex-wrap:wrap;}
.skb-sechead p{margin:.4rem 0 0;color:var(--plum-muted);font-weight:500;}

/* ============ Resort cards ============ */
.skb-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:2rem;}
.skb-rcard{background:#fff;border:1px solid var(--pink-50);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-card);
  transition:transform .3s cubic-bezier(.34,1.56,.64,1),box-shadow .3s;display:flex;flex-direction:column;}
.skb-rcard:hover{transform:translateY(-8px);box-shadow:var(--shadow-hover);}
.skb-rcard__media{height:13rem;position:relative;background:var(--bg-pink);}
.skb-rcard__media img{width:100%;height:100%;object-fit:cover;}
.skb-rcard__rating{position:absolute;top:1rem;left:1rem;background:rgba(255,255,255,.92);backdrop-filter:blur(4px);
  padding:.25rem .6rem;border-radius:var(--radius-pill);font-size:.78rem;font-weight:700;color:var(--plum-dark);display:flex;align-items:center;gap:.25rem;}
.skb-rcard__rating .skb-icon{color:#F6B72F;fill:#F6B72F;}
.skb-rcard__body{padding:1.5rem;display:flex;flex-direction:column;flex:1;}
.skb-rcard__country{color:var(--primary);font-weight:700;font-size:.75rem;text-transform:uppercase;letter-spacing:.08em;margin-bottom:.2rem;}
.skb-rcard h3{font-size:1.4rem;margin-bottom:1rem;}
.skb-chips{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.25rem;}
.skb-chip{background:var(--grey-50);padding:.3rem .65rem;border-radius:10px;font-size:.75rem;font-weight:600;display:inline-flex;align-items:center;gap:.4rem;color:var(--plum-main);}
.skb-chip .skb-icon{color:var(--plum-muted);font-size:.95rem;}
.skb-rcard__foot{display:flex;align-items:center;justify-content:space-between;margin-top:auto;}
.skb-rcard__foot a{font-weight:700;font-size:.85rem;color:var(--plum-main);display:inline-flex;align-items:center;gap:.2rem;}
.skb-rcard__foot a:hover{color:var(--primary);}
/* elevation mini bars */
.skb-elev{display:flex;align-items:flex-end;gap:2px;height:1.5rem;}
.skb-elev span{width:3px;background:#D9C7D0;border-radius:3px;}
.skb-elev span.on{background:var(--primary);}

/* ============ Country tiles ============ */
.skb-countries{display:flex;gap:1.5rem;overflow-x:auto;padding-bottom:1.5rem;scrollbar-width:thin;}
.skb-ctile{flex:0 0 auto;width:12rem;height:16rem;background:#fff;border:1px solid var(--pink-100);border-radius:2.5rem;
  padding:1.5rem;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;box-shadow:var(--shadow-card);transition:transform .2s;}
.skb-ctile:hover{transform:translateY(-8px);}
.skb-ctile__badge{width:4rem;height:4rem;border-radius:50%;background:var(--bg-pink);display:flex;align-items:center;justify-content:center;
  margin-bottom:1rem;font-family:'Poppins';font-weight:800;font-size:1.1rem;color:var(--primary);letter-spacing:.02em;}
.skb-ctile h4{margin:0 0 .2rem;font-size:1.25rem;}
.skb-ctile p{margin:0;color:var(--plum-muted);font-size:.9rem;font-weight:500;}

/* ============ Guide cards ============ */
.skb-guides{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:2.5rem;}
.skb-gcard{display:flex;flex-direction:column;}
.skb-gcard__media{display:block;height:16rem;border-radius:2.5rem;overflow:hidden;margin-bottom:1.5rem;background:var(--bg-pink);}
.skb-gcard__media img{width:100%;height:100%;object-fit:cover;transition:transform .5s;}
.skb-gcard:hover .skb-gcard__media img{transform:scale(1.05);}
.skb-gcard h3{margin:.5rem 0 .6rem;font-size:1.4rem;}
.skb-gcard:hover h3{color:var(--primary);}
.skb-gcard__more{font-weight:700;font-size:.85rem;border-bottom:2px solid var(--primary);padding-bottom:1px;}

/* ============ Feature band (kids ski free) ============ */
.skb-band{background:var(--plum-dark);border-radius:3rem;padding:4rem;position:relative;overflow:hidden;color:#fff;}
.skb-band__in{position:relative;z-index:2;max-width:60%;}
.skb-band h2{color:#fff;}
.skb-band p{color:#FFD9EA;font-size:1.15rem;max-width:30rem;margin-bottom:2rem;}
.skb-band__tag{display:inline-block;background:var(--primary);color:#fff;font-size:.65rem;font-weight:900;text-transform:uppercase;letter-spacing:.2em;padding:.3rem .7rem;border-radius:6px;margin-bottom:1.5rem;}
.skb-band__deco{position:absolute;right:-3rem;bottom:-4rem;opacity:.15;color:#fff;width:380px;height:380px;}

/* ============ How it works ============ */
.skb-steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:3rem;text-align:center;}
.skb-step__ico{width:5.5rem;height:5.5rem;background:var(--bg-pink);border-radius:2rem;display:flex;align-items:center;justify-content:center;margin:0 auto 1.5rem;color:var(--primary);}
.skb-step__ico .skb-icon{font-size:2.2rem;}
.skb-step h4{font-size:1.4rem;}

/* ============ Quiz / split CTA ============ */
.skb-split{background:var(--bg-pink);border-radius:3rem;overflow:hidden;display:flex;flex-wrap:wrap;align-items:stretch;}
.skb-split__txt{flex:1 1 340px;padding:4rem;}
.skb-split__img{flex:1 1 340px;min-height:340px;background:var(--plum-main);}
.skb-split__img img{width:100%;height:100%;object-fit:cover;}

/* ============ Newsletter ============ */
.skb-news{text-align:center;border-top:1px solid var(--pink-100);}
.skb-news form{display:flex;gap:1rem;max-width:32rem;margin:1.5rem auto 0;flex-wrap:wrap;}
.skb-news input{flex:1;min-width:200px;padding:1rem 1.5rem;border:1px solid var(--pink-100);border-radius:var(--radius-pill);font-family:inherit;outline:none;}
.skb-news input:focus{border-color:var(--primary);}

/* ============ Footer ============ */
.skb-footer{background:var(--plum-dark);color:#fff;padding:5rem 0 3rem;}
.skb-footer__grid{display:grid;grid-template-columns:2fr repeat(4,1fr);gap:3rem;margin-bottom:4rem;}
.skb-footer__brand p{color:rgba(255,217,234,.6);max-width:18rem;font-weight:500;}
.skb-footer h5{color:#fff;font-family:'Poppins';font-weight:700;margin-bottom:1.25rem;}
.skb-footer ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.85rem;}
.skb-footer a{color:rgba(255,217,234,.6);font-size:.9rem;font-weight:500;}
.skb-footer a:hover{color:#fff;}
.skb-social{display:flex;gap:.75rem;margin-top:1.5rem;}
.skb-social a{width:2.5rem;height:2.5rem;border-radius:50%;background:rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;color:#fff;transition:background .2s;}
.skb-social a:hover{background:var(--primary);}
.skb-footer__bar{padding-top:2.5rem;border-top:1px solid rgba(255,255,255,.1);display:flex;flex-wrap:wrap;gap:1rem;align-items:center;justify-content:space-between;}
.skb-footer__bar a,.skb-footer__bar span{color:rgba(255,217,234,.4);font-size:.78rem;font-weight:500;}
.skb-footer__bar a:hover{color:#fff;}

/* ============ Article / single ============ */
.skb-article{max-width:760px;margin:0 auto;padding:3rem 1.5rem 4rem;}
.skb-article__head{max-width:820px;margin:0 auto 2rem;text-align:center;}
.skb-article__meta{color:var(--plum-muted);font-size:.9rem;margin-top:1rem;display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;}
.skb-article__hero{max-width:1000px;margin:0 auto 2.5rem;border-radius:var(--radius-lg);overflow:hidden;}
.skb-prose{font-size:1.08rem;}
.skb-prose h2{margin-top:2.2rem;}
.skb-prose h3{margin-top:1.6rem;}
.skb-prose img{border-radius:var(--radius);margin:1.5rem 0;}
.skb-prose a{color:var(--primary);text-decoration:underline;text-underline-offset:2px;}
.skb-prose ul,.skb-prose ol{padding-left:1.3rem;}
.skb-prose blockquote{border-left:none;background:var(--bg-pink);border-radius:var(--radius);padding:1.25rem 1.5rem;margin:1.5rem 0;font-style:italic;}
.skb-prose table{width:100%;border-collapse:collapse;margin:1.5rem 0;font-size:.95rem;}
.skb-prose th{background:var(--plum-main);color:#fff;text-align:left;padding:.6rem .8rem;font-family:'Poppins';font-weight:600;font-size:.85rem;}
.skb-prose td{padding:.55rem .8rem;border-bottom:1px solid var(--line);}
.skb-prose tr:nth-child(even) td{background:var(--pink-50);}
.skb-prose figure{margin:1.5rem 0;}
.skb-prose figcaption{font-size:.82rem;color:var(--plum-muted);margin-top:.5rem;text-align:center;}
.skb-infographic svg{width:100%;height:auto;border:1px solid var(--line);border-radius:var(--radius);background:#fff;}
.skb-prose textarea{width:100%;}

/* ============ FAQ accordion ============ */
.skb-faq{max-width:760px;margin:2.5rem auto;}
.skb-faq details{background:#fff;border:1px solid var(--pink-100);border-radius:var(--radius);margin-bottom:.85rem;overflow:hidden;}
.skb-faq summary{cursor:pointer;padding:1.1rem 1.4rem;font-family:'Poppins';font-weight:600;color:var(--plum-dark);list-style:none;display:flex;justify-content:space-between;align-items:center;gap:1rem;}
.skb-faq summary::-webkit-details-marker{display:none;}
.skb-faq summary::after{content:'+';font-size:1.4rem;color:var(--primary);font-weight:400;transition:transform .2s;}
.skb-faq details[open] summary::after{transform:rotate(45deg);}
.skb-faq__body{padding:0 1.4rem 1.2rem;color:var(--plum-main);}

/* ============ EEAT author block ============ */
.skb-author{display:flex;gap:1rem;align-items:center;background:var(--bg-pink);border-radius:var(--radius);padding:1.25rem;margin:2.5rem auto;max-width:760px;}
.skb-author img{width:64px;height:64px;border-radius:50%;object-fit:cover;flex:0 0 auto;}
.skb-author__name{font-family:'Poppins';font-weight:700;color:var(--plum-dark);}
.skb-author__role{color:var(--primary);font-size:.85rem;font-weight:600;}
.skb-author__bio{font-size:.9rem;color:var(--plum-muted);margin-top:.25rem;}

/* ============ Resort single ============ */
.skb-rhero{background:linear-gradient(135deg,#FFFCF9,#FFE5F1);padding:3rem 0;}
.skb-rhero__grid{display:grid;grid-template-columns:1.3fr 1fr;gap:2.5rem;align-items:center;}
.skb-rhero__media{aspect-ratio:4/3;border-radius:var(--radius-lg);overflow:hidden;background:var(--bg-pink);box-shadow:var(--shadow-card);}
.skb-rhero__media img,.skb-rhero__media svg{width:100%;height:100%;object-fit:cover;display:block;}
.skb-statgrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:1rem;margin:2rem 0;}
.skb-stat{background:#fff;border:1px solid var(--pink-100);border-radius:var(--radius);padding:1.1rem;text-align:center;}
.skb-stat__val{font-family:'Poppins';font-weight:800;font-size:1.5rem;color:var(--plum-dark);}
.skb-stat__lbl{font-size:.78rem;color:var(--plum-muted);text-transform:uppercase;letter-spacing:.05em;margin-top:.2rem;}
.skb-pistebar{display:flex;height:14px;border-radius:7px;overflow:hidden;margin:.5rem 0 1.5rem;}
.skb-pistebar i{display:block;height:100%;}
.skb-pistebar .easy{background:#3FA7E0;}.skb-pistebar .med{background:#E0403F;}.skb-pistebar .hard{background:#322838;}
.skb-rhero__linked{font-family:'Poppins',sans-serif;font-weight:600;color:var(--primary);font-size:1rem;margin:.4rem 0 .6rem;line-height:1.4;}
.skb-breadcrumb{font-size:.85rem;color:var(--plum-muted);margin-bottom:1rem;}
.skb-breadcrumb a:hover{color:var(--primary);}

/* ============ Directory archive + filters ============ */
.skb-dir{display:grid;grid-template-columns:260px 1fr;gap:2.5rem;align-items:start;}
.skb-filters{background:#fff;border:1px solid var(--pink-100);border-radius:var(--radius-lg);padding:1.5rem;position:sticky;top:6rem;}
.skb-filters h4{font-size:1rem;margin:1.2rem 0 .6rem;}
.skb-filters label{display:flex;align-items:center;gap:.5rem;font-size:.9rem;margin-bottom:.4rem;color:var(--plum-main);cursor:pointer;}

/* ============ Pagination ============ */
.skb-pag{display:flex;gap:.5rem;justify-content:center;margin-top:3rem;flex-wrap:wrap;}
.skb-pag a,.skb-pag span{padding:.5rem .9rem;border-radius:10px;border:1px solid var(--pink-100);font-weight:600;color:var(--plum-main);}
.skb-pag .current{background:var(--primary);color:#fff;border-color:var(--primary);}

/* ============ Responsive ============ */
@media(max-width:900px){
  .skb-footer__grid{grid-template-columns:1fr 1fr;}
  .skb-dir{grid-template-columns:1fr;}
  .skb-filters{position:static;}
  .skb-rhero__grid{grid-template-columns:1fr;}
  .skb-band__in{max-width:100%;}
}
@media(max-width:768px){
  .skb-nav,.skb-langs{display:none;}
  .skb-burger{display:inline-flex;}
  .skb-nav.is-open{display:flex;position:absolute;top:5rem;left:0;right:0;background:var(--bg-warm);flex-direction:column;padding:1.5rem;gap:1rem;border-bottom:1px solid var(--pink-100);}
  .skb-section{padding:3.5rem 0;}
  .skb-hero{padding:4rem 0 3.5rem;}
  .skb-footer__grid{grid-template-columns:1fr;gap:2rem;}
  .skb-split__txt,.skb-band{padding:2.5rem;}
}
