/*
Theme Name: OIKO
Theme URI: https://example.com/oiko
Author: NextSite
Author URI: https://example.com
Description: OIKO – "Stories that connect the world." A nature, wildlife and sustainability media/journalism WordPress theme with a magazine-style homepage, featured video section and original productions grid.
Version: 1.0.0
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: oiko
Tags: news, blog, video, magazine, custom-menu, featured-images, translation-ready
*/

/* -------------------------------------------------
   0. RESET & BASE
------------------------------------------------- */
:root{
  --oiko-green:#2e8b3d;
  --oiko-green-dark:#1f6b2c;
  --oiko-orange:#f5a623;
  --oiko-blue:#1656b0;
  --oiko-navy:#001d3d;
  --oiko-black:#111214;
  --oiko-text:#1b1c1e;
  --oiko-text-light:#6b6f76;
  --oiko-bg:#f6f6f4;
  --oiko-white:#ffffff;
  --oiko-border:#e7e6e2;
  --font-display:'Bebas Neue', 'Oswald', Impact, sans-serif;
  --font-body:'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
}

*,*::before,*::after{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  font-family:var(--font-body);
  color:var(--oiko-text);
  background:var(--oiko-bg);
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
ul{list-style:none;margin:0;padding:0;}
button{font-family:inherit;cursor:pointer;}
.container{max-width:1320px;margin:0 auto;padding:0 24px;}
h1,h2,h3,h4{font-family:var(--font-display);letter-spacing:.02em;margin:0;}
.visually-hidden{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0);}

/* Focus visibility for accessibility */
a:focus-visible,button:focus-visible,input:focus-visible{
  outline:3px solid var(--oiko-blue);
  outline-offset:2px;
}
@media (prefers-reduced-motion: reduce){
  *{animation-duration:.001ms !important;transition-duration:.001ms !important;}
}

/* -------------------------------------------------
   1. TOP HEADER
------------------------------------------------- */
.site-header{
  background:var(--oiko-white);
  border-bottom:1px solid var(--oiko-border);
  position:sticky;top:0;z-index:50;
}
.site-header__inner{
  display:flex;align-items:center;justify-content:space-between;
  padding:16px 24px;gap:24px;
}
.site-logo{display:flex;align-items:center;gap:12px;}
.site-logo__mark{width:44px;height:36px;flex-shrink:0;}
.site-logo__text{display:flex;flex-direction:column;line-height:1;}
.site-logo__word{font-family:var(--font-display);font-size:28px;letter-spacing:.03em;color:var(--oiko-black);}
.site-logo__tag{font-size:9px;letter-spacing:.14em;color:var(--oiko-text-light);font-weight:600;text-transform:uppercase;}

.main-nav{display:flex;}
.main-nav ul{display:flex;gap:28px;}
.main-nav a{
  font-size:13px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;
  color:var(--oiko-text);padding:8px 0;border-bottom:2px solid transparent;
  transition:color .15s, border-color .15s;
}
.main-nav a:hover,.main-nav .current-menu-item a{
  color:var(--oiko-green-dark);border-color:var(--oiko-green-dark);
}

.header-actions{display:flex;align-items:center;gap:20px;}
.header-search{
  background:none;border:none;width:20px;height:20px;color:var(--oiko-text);
}
.btn{
  display:inline-flex;align-items:center;gap:6px;
  font-size:13px;font-weight:700;letter-spacing:.03em;text-transform:uppercase;
  padding:10px 20px;border-radius:4px;border:none;transition:background .15s, transform .1s;
}
.btn:active{transform:translateY(1px);}
.btn--primary{background:var(--oiko-blue);color:var(--oiko-white);}
.btn--primary:hover{background:#0e3f82;}
.btn--outline{background:transparent;border:1px solid var(--oiko-border);color:var(--oiko-text);}
.lang-switch{
  display:flex;align-items:center;gap:4px;font-size:13px;font-weight:700;color:var(--oiko-text);
}
.menu-toggle{display:none;background:none;border:none;font-size:26px;}

/* -------------------------------------------------
   2. HERO SLIDER
------------------------------------------------- */
.hero-slider{position:relative;background:var(--oiko-black);overflow:hidden;}
.hero-slide{
  position:relative;min-height:460px;display:flex;align-items:flex-end;
  background-size:cover;background-position:center;
}
.hero-slide::before{
  content:"";position:absolute;inset:0;
  background:linear-gradient(90deg, rgba(0,0,0,.78) 10%, rgba(0,0,0,.35) 45%, rgba(0,0,0,.05) 70%);
}
.hero-slide__content{position:relative;z-index:2;color:#fff;max-width:560px;padding:48px 24px 56px;}
.hero-slide__eyebrow{
  color:var(--oiko-green);font-weight:800;font-size:12px;letter-spacing:.16em;
  text-transform:uppercase;margin-bottom:12px;display:block;
}
.hero-slide__title{font-size:44px;line-height:1.05;margin-bottom:16px;text-transform:uppercase;}
.hero-slide__excerpt{font-size:15px;color:#e7e7e7;margin-bottom:22px;max-width:460px;}
.hero-slide .btn--primary{background:var(--oiko-green);}
.hero-slide .btn--primary:hover{background:var(--oiko-green-dark);}

.hero-arrow{
  position:absolute;top:50%;transform:translateY(-50%);z-index:3;
  width:44px;height:44px;border-radius:50%;border:1.5px solid rgba(255,255,255,.7);
  background:rgba(0,0,0,.25);color:#fff;font-size:20px;display:flex;align-items:center;justify-content:center;
}
.hero-arrow--prev{left:20px;}
.hero-arrow--next{right:20px;}
.hero-dots{
  position:absolute;bottom:18px;left:50%;transform:translateX(-50%);z-index:3;
  display:flex;gap:8px;
}
.hero-dots button{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,.45);border:none;padding:0;}
.hero-dots button.is-active{background:#fff;}

/* -------------------------------------------------
   3. CATEGORY STRIP
------------------------------------------------- */
.category-strip{
  background:var(--oiko-white);margin:-30px 24px 0;position:relative;z-index:5;
  border-radius:8px;box-shadow:0 8px 24px rgba(0,0,0,.08);
  max-width:1272px;margin-left:auto;margin-right:auto;
}
.category-strip ul{display:flex;justify-content:space-between;padding:18px 32px;flex-wrap:wrap;gap:12px;}
.category-strip a{
  display:flex;align-items:center;gap:8px;font-size:13px;font-weight:800;
  letter-spacing:.03em;text-transform:uppercase;color:var(--oiko-text);
}
.category-strip .cat-dot{width:20px;height:20px;border-radius:5px;display:flex;align-items:center;justify-content:center;font-size:12px;}
.cat-dot--nature{background:#e5f4e8;color:var(--oiko-green);}
.cat-dot--animals{background:#fdeccf;color:var(--oiko-orange);}
.cat-dot--planet{background:#e2ecfb;color:var(--oiko-blue);}
.cat-dot--sustainability{background:#e5f4e8;color:var(--oiko-green);}
.cat-dot--cultures{background:#fdeccf;color:var(--oiko-orange);}
.cat-dot--science{background:#e2ecfb;color:var(--oiko-blue);}

/* -------------------------------------------------
   4. SECTION HEADINGS
------------------------------------------------- */
.section{padding:56px 0 8px;}
.section__head{
  display:flex;align-items:center;justify-content:space-between;margin-bottom:22px;
}
.section__title{font-size:24px;letter-spacing:.03em;text-transform:uppercase;}
.section__link{font-size:12px;font-weight:800;letter-spacing:.05em;text-transform:uppercase;color:var(--oiko-green-dark);}

/* -------------------------------------------------
   5. FEATURED NEWS GRID
------------------------------------------------- */
.news-grid{display:grid;grid-template-columns:repeat(4,1fr) 1.2fr;gap:20px;align-items:stretch;}
.news-card{
  position:relative;border-radius:8px;overflow:hidden;min-height:280px;
  background-size:cover;background-position:center;display:flex;align-items:flex-end;
  color:#fff;
}
.news-card::before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,0) 40%,rgba(0,0,0,.85) 100%);}
.news-card__body{position:relative;z-index:2;padding:16px;}
.news-card__badge{
  display:inline-block;font-size:10px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;
  padding:4px 8px;border-radius:3px;margin-bottom:10px;
}
.badge--planet{background:var(--oiko-blue);}
.badge--nature{background:var(--oiko-green);}
.badge--sustainability{background:var(--oiko-orange);color:#2b2100;}
.badge--cultures{background:var(--oiko-navy);}
.news-card__title{font-size:16px;font-family:var(--font-body);font-weight:800;line-height:1.3;margin-bottom:8px;}
.news-card__time{font-size:11px;color:#d8d8d8;}

.promo-card{
  background:var(--oiko-white);border-radius:8px;padding:26px 22px;
  display:flex;flex-direction:column;justify-content:center;gap:14px;
  border:1px solid var(--oiko-border);
}
.promo-card__logo{width:34px;height:28px;}
.promo-card__title{font-family:var(--font-display);font-size:22px;text-transform:uppercase;}
.promo-card p{font-size:13px;color:var(--oiko-text-light);margin:0;}

/* -------------------------------------------------
   6. VIDEO SECTION (dark)
------------------------------------------------- */
.video-section{background:var(--oiko-black);color:#fff;padding:48px 0;margin-top:32px;}
.video-section .container{display:grid;grid-template-columns:2.6fr 1fr;gap:20px;}
.video-section__head{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;}
.video-section__title{font-size:20px;letter-spacing:.03em;text-transform:uppercase;}
.video-section__link{font-size:11px;font-weight:800;color:var(--oiko-green);text-transform:uppercase;letter-spacing:.05em;}
.video-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;}
.video-card{position:relative;border-radius:6px;overflow:hidden;background-size:cover;background-position:center;min-height:140px;display:flex;align-items:flex-end;}
.video-card::before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,0) 55%,rgba(0,0,0,.85) 100%);}
.video-card__play{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:2;
  width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,.9);
  display:flex;align-items:center;justify-content:center;color:#111;font-size:14px;
}
.video-card__duration{position:absolute;top:8px;right:8px;font-size:10px;background:rgba(0,0,0,.6);padding:2px 6px;border-radius:3px;z-index:2;}
.video-card__title{position:relative;z-index:2;font-size:12px;font-weight:700;padding:10px;}

.upcoming-card{background:#1a1b1d;border-radius:8px;overflow:hidden;}
.upcoming-card__head{padding:16px 16px 0;font-size:16px;letter-spacing:.03em;text-transform:uppercase;}
.upcoming-card__img{height:120px;background-size:cover;background-position:center;margin:14px 0;}
.upcoming-card__body{padding:0 16px 18px;}
.upcoming-card__title{font-family:var(--font-body);font-weight:800;font-size:15px;margin-bottom:6px;}
.upcoming-card__desc{font-size:12.5px;color:#b7b8ba;margin-bottom:10px;}
.upcoming-card__meta{font-size:11px;color:var(--oiko-green);font-weight:700;}

/* -------------------------------------------------
   7. ORIGINAL PRODUCTIONS
------------------------------------------------- */
.productions-row{display:grid;grid-template-columns:repeat(4,1fr) 1.3fr;gap:20px;}
.poster-card{position:relative;border-radius:8px;overflow:hidden;min-height:230px;background-size:cover;background-position:center;display:flex;align-items:flex-end;color:#fff;}
.poster-card::before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,0) 50%,rgba(0,0,0,.85) 100%);}
.poster-card__tag{position:absolute;top:10px;left:10px;font-size:10px;font-weight:800;background:rgba(0,0,0,.55);padding:3px 7px;border-radius:3px;text-transform:uppercase;letter-spacing:.05em;z-index:2;}
.poster-card__title{position:relative;z-index:2;padding:14px;font-size:16px;font-weight:800;font-family:var(--font-body);}

.curiosity-card{
  background:var(--oiko-orange);border-radius:8px;overflow:hidden;color:#2b2100;
  display:flex;flex-direction:column;
}
.curiosity-card__top{padding:18px 20px 0;}
.curiosity-card__label{display:flex;align-items:center;gap:6px;font-size:11px;font-weight:800;letter-spacing:.05em;text-transform:uppercase;margin-bottom:10px;}
.curiosity-card__title{font-family:var(--font-body);font-size:16px;font-weight:800;margin-bottom:6px;}
.curiosity-card__text{font-size:13px;margin-bottom:14px;}
.curiosity-card__btn{
  display:inline-block;background:#20200f;color:#fff;font-size:11px;font-weight:800;
  padding:8px 14px;border-radius:4px;letter-spacing:.04em;text-transform:uppercase;margin:0 20px 18px;align-self:flex-start;
}
.curiosity-card__img{flex:1;background-size:cover;background-position:center;min-height:100px;}

/* -------------------------------------------------
   8. NEWSLETTER BAR
------------------------------------------------- */
.newsletter{background:var(--oiko-blue);color:#fff;padding:20px 0;margin-top:56px;}
.newsletter .container{display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap;}
.newsletter__left{display:flex;align-items:center;gap:14px;}
.newsletter__title{font-size:14px;font-weight:800;letter-spacing:.03em;text-transform:uppercase;}
.newsletter__sub{font-size:12.5px;color:#dce6f7;}
.newsletter-form{display:flex;gap:0;}
.newsletter-form input{
  border:none;padding:12px 16px;font-size:13px;width:260px;border-radius:4px 0 0 4px;
}
.newsletter-form button{
  background:var(--oiko-green);color:#fff;border:none;padding:0 20px;font-weight:800;
  font-size:12px;letter-spacing:.04em;text-transform:uppercase;border-radius:0 4px 4px 0;
}
.social-icons{display:flex;align-items:center;gap:14px;}
.social-icons span{font-size:12px;font-weight:800;letter-spacing:.05em;text-transform:uppercase;margin-right:4px;}
.social-icons a{width:30px;height:30px;border-radius:50%;background:rgba(255,255,255,.15);display:flex;align-items:center;justify-content:center;font-size:13px;}

/* -------------------------------------------------
   9. FOOTER
------------------------------------------------- */
.site-footer{background:var(--oiko-black);color:#c9cacc;padding:44px 0 24px;}
.footer-grid{display:grid;grid-template-columns:1.3fr 1fr 1fr 1fr 1.4fr;gap:24px;margin-bottom:32px;}
.footer-logo{display:flex;align-items:center;gap:10px;margin-bottom:12px;}
.footer-logo__word{font-family:var(--font-display);font-size:24px;color:#fff;letter-spacing:.03em;}
.footer-col h4{font-size:12px;letter-spacing:.06em;color:#8d8f92;text-transform:uppercase;margin-bottom:14px;font-family:var(--font-body);font-weight:800;}
.footer-col ul li{margin-bottom:9px;}
.footer-col a{font-size:13px;color:#c9cacc;}
.footer-col a:hover{color:#fff;}
.footer-about p{font-size:12.5px;color:#8d8f92;line-height:1.6;}
.footer-bottom{border-top:1px solid #2a2b2d;padding-top:18px;font-size:12px;color:#7d7f82;}

/* -------------------------------------------------
   10. RESPONSIVE
------------------------------------------------- */
@media (max-width: 1080px){
  .news-grid,.productions-row{grid-template-columns:repeat(2,1fr);}
  .video-section .container{grid-template-columns:1fr;}
  .video-grid{grid-template-columns:repeat(2,1fr);}
  .footer-grid{grid-template-columns:repeat(2,1fr);}
}
@media (max-width: 760px){
  .main-nav{display:none;}
  .menu-toggle{display:block;}
  .hero-slide__title{font-size:30px;}
  .news-grid,.productions-row{grid-template-columns:1fr;}
  .video-grid{grid-template-columns:1fr;}
  .category-strip ul{justify-content:flex-start;overflow-x:auto;}
  .newsletter .container{flex-direction:column;align-items:flex-start;}
  .footer-grid{grid-template-columns:1fr;}
}
