/*
Theme Name: GFish — Риболовля
Theme URI: https://gfish.com.ua/
Author: GFish Studio
Author URI: https://gfish.com.ua/
Description: Повноцінна WordPress-тема для багатосторінкового сайту про риболовлю. Має кастомні типи записів «Патерни» (приманки/мухи), «Події» (змагання та виїзди) і «Товари» (вітрина магазину), шаблони сторінок «Про нас», «FAQs», «Автори», «Контакти», а також готовий демо-контент українською мовою.
Version: 1.0.0
Requires at least: 6.4
Tested up to: 6.7
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: gfish
Tags: blog, e-commerce, custom-post-types, custom-menu, featured-images, threaded-comments, translation-ready
*/

/* ==========================================================================
   ДИЗАЙН-ТОКЕНИ
   Палітра побудована навколо води та риболовецького знаряддя:
   глибока вода, річкова бірюза, пісок мілини, мідь блешні.
   ========================================================================== */
:root{
  /* кольори */
  --c-deepwater: #0B3142;
  --c-river: #1B6E7A;
  --c-river-light: #3C99A6;
  --c-sand: #E8DCC2;
  --c-sand-light: #F3ECDA;
  --c-foam: #FAF7F0;
  --c-copper: #C1622D;
  --c-copper-dark: #9C4A1F;
  --c-ink: #1A1A18;
  --c-ink-soft: #55534C;
  --c-line: rgba(11,49,66,.14);
  --c-white: #ffffff;

  /* типографіка */
  --f-display: "Oswald", "Arial Narrow", sans-serif;
  --f-body: "Inter", -apple-system, BlinkMacSystemFont, sans-serif;
  --f-mono: "IBM Plex Mono", "Courier New", monospace;

  /* розміри */
  --container: 1180px;
  --container-narrow: 760px;
  --radius-s: 4px;
  --radius-m: 8px;
  --gutter: clamp(20px, 4vw, 48px);
  --section-pad: clamp(56px, 9vw, 110px);
}

/* ==========================================================================
   RESET / БАЗА
   ========================================================================== */
*,*::before,*::after{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  background:var(--c-foam);
  color:var(--c-ink);
  font-family:var(--f-body);
  font-size:17px;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;height:auto;display:block;}
a{color:var(--c-river);text-decoration:none;}
a:hover{color:var(--c-copper);}
ul{margin:0;padding:0;}
button{font-family:inherit;cursor:pointer;}
:focus-visible{outline:3px solid var(--c-copper);outline-offset:2px;}

h1,h2,h3,h4{
  font-family:var(--f-display);
  font-weight:600;
  line-height:1.12;
  letter-spacing:.2px;
  color:var(--c-deepwater);
  margin:0 0 .5em;
  text-transform:uppercase;
}
h1{font-size:clamp(34px,5.2vw,58px);}
h2{font-size:clamp(26px,3.6vw,38px);}
h3{font-size:20px;}
p{margin:0 0 1.2em;}
.lead{font-size:20px;color:var(--c-ink-soft);font-family:var(--f-body);text-transform:none;font-weight:400;}

.container{max-width:var(--container);margin:0 auto;padding:0 var(--gutter);}
.container--narrow{max-width:var(--container-narrow);}
.screen-reader-text{position:absolute;left:-9999px;}

/* eyebrow / лейбл-«бирка» у стилі етикетки снасті */
.eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--f-mono);
  font-size:12px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--c-copper-dark);
  margin-bottom:14px;
}
.eyebrow::before{content:"";width:18px;height:2px;background:var(--c-copper);}

/* ==========================================================================
   КНОПКИ І ТЕГИ
   ========================================================================== */
.btn{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--f-display);font-size:14px;letter-spacing:.06em;text-transform:uppercase;
  padding:13px 26px;border-radius:var(--radius-s);
  border:2px solid var(--c-deepwater);
  background:var(--c-deepwater);color:var(--c-foam);
  transition:transform .15s ease, background .2s ease, color .2s ease;
}
.btn:hover{background:var(--c-copper);border-color:var(--c-copper);color:#fff;transform:translateY(-2px);}
.btn--ghost{background:transparent;color:var(--c-deepwater);}
.btn--ghost:hover{background:var(--c-deepwater);color:var(--c-foam);}
.btn--copper{background:var(--c-copper);border-color:var(--c-copper);}
.btn--copper:hover{background:var(--c-deepwater);border-color:var(--c-deepwater);}

/* «показники приладу» — теги виду глибиноміра: вид риби, сезон, дата */
.tag-row{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px;}
.tag{
  font-family:var(--f-mono);font-size:12px;letter-spacing:.05em;
  padding:4px 10px;border-radius:20px;
  background:var(--c-sand);color:var(--c-deepwater);
  border:1px solid var(--c-line);
}
.tag--copper{background:var(--c-copper);color:#fff;border-color:var(--c-copper);}

/* ==========================================================================
   КОНТУРНИЙ РОЗДІЛЬНИК (фірмовий елемент: лінії глибини, як на ехолоті/карті)
   ========================================================================== */
.contour-divider{display:block;width:100%;height:46px;color:var(--c-river);opacity:.55;}
.contour-divider--invert{color:var(--c-sand);opacity:.9;}
.contour-divider svg{width:100%;height:100%;display:block;}

/* ==========================================================================
   ШАПКА САЙТУ
   ========================================================================== */
.site-header{
  position:sticky;top:0;z-index:50;
  background:var(--c-foam);
  border-bottom:1px solid var(--c-line);
}
.header-inner{
  display:flex;align-items:center;justify-content:space-between;
  padding:16px var(--gutter);max-width:var(--container);margin:0 auto;gap:18px;
}
.site-branding{display:flex;align-items:center;gap:12px;}
.site-branding .logo-mark{
  width:42px;height:42px;flex:0 0 auto;color:var(--c-copper);
}
.site-title{
  font-family:var(--f-display);font-size:24px;letter-spacing:.04em;
  color:var(--c-deepwater);text-transform:uppercase;margin:0;
}
.site-title a{color:inherit;}
.site-description{
  display:block;font-family:var(--f-mono);font-size:11px;letter-spacing:.08em;
  color:var(--c-ink-soft);text-transform:uppercase;
}

.main-navigation{display:flex;align-items:center;gap:18px;}
.main-navigation ul{display:flex;gap:18px;list-style:none;}
.main-navigation a{
  font-family:var(--f-display);font-size:13px;letter-spacing:.04em;text-transform:uppercase;
  color:var(--c-deepwater);padding:6px 0;position:relative;white-space:nowrap;
}
.main-navigation a::after{
  content:"";position:absolute;left:0;bottom:-2px;width:0;height:2px;background:var(--c-copper);
  transition:width .2s ease;
}
.main-navigation a:hover::after,
.main-navigation .current-menu-item>a::after{width:100%;}
.main-navigation .current-menu-item>a{color:var(--c-copper-dark);}

.menu-toggle{
  display:none;background:none;border:2px solid var(--c-deepwater);border-radius:var(--radius-s);
  width:42px;height:38px;align-items:center;justify-content:center;
}
.menu-toggle span,.menu-toggle span::before,.menu-toggle span::after{
  content:"";display:block;width:20px;height:2px;background:var(--c-deepwater);position:relative;
}
.menu-toggle span::before{top:-6px;}
.menu-toggle span::after{top:4px;}

.header-search{display:flex;align-items:center;}
.header-search .search-field{
  font-family:var(--f-body);border:1px solid var(--c-line);border-radius:20px;
  padding:7px 12px;font-size:13px;width:120px;background:var(--c-white);
}

@media (max-width: 980px){
  .menu-toggle{display:flex;}
  .main-navigation{
    position:absolute;top:100%;left:0;right:0;background:var(--c-foam);
    border-bottom:1px solid var(--c-line);flex-direction:column;align-items:stretch;
    padding:10px var(--gutter) 20px;display:none;
  }
  .main-navigation.is-open{display:flex;}
  .main-navigation ul{flex-direction:column;gap:4px;}
  .main-navigation li{border-bottom:1px solid var(--c-line);}
  .main-navigation a{display:block;padding:12px 0;}
  .header-search{display:none;}
}

@media (max-width: 480px){
  .site-title{font-size:18px;}
  .site-description{display:none;}
  .header-inner{flex-wrap:wrap;}
}

/* ==========================================================================
   ГЕРОЙ ГОЛОВНОЇ
   ========================================================================== */
.hero{
  position:relative;overflow:hidden;
  background:linear-gradient(160deg, var(--c-deepwater) 0%, #103E50 55%, var(--c-river) 100%);
  color:var(--c-foam);padding:var(--section-pad) 0 0;
}
.hero-inner{
  max-width:var(--container);margin:0 auto;padding:0 var(--gutter) 90px;
  display:grid;grid-template-columns:1.1fr .9fr;gap:48px;align-items:center;
}
.hero h1{color:var(--c-foam);}
.hero .eyebrow{color:var(--c-sand);}
.hero .eyebrow::before{background:var(--c-copper);}
.hero p.lead{color:var(--c-sand);}
.hero-actions{display:flex;gap:14px;margin-top:28px;flex-wrap:wrap;}
.hero-figure{position:relative;}
.hero-figure svg{width:100%;height:auto;}
.hero-stats{display:flex;gap:28px;margin-top:34px;flex-wrap:wrap;}
.hero-stats div{font-family:var(--f-mono);}
.hero-stats strong{display:block;font-family:var(--f-display);font-size:30px;color:var(--c-foam);}
.hero-stats span{font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--c-sand);}
.hero .contour-divider{position:relative;margin-top:-2px;}

@media (max-width: 880px){
  .hero-inner{grid-template-columns:1fr;}
  .hero-figure{order:-1;max-width:280px;margin:0 auto;}
}

/* ==========================================================================
   СЕКЦІЇ ГОЛОВНОЇ
   ========================================================================== */
.section{padding:var(--section-pad) 0;}
.section--sand{background:var(--c-sand-light);}
.section-head{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;margin-bottom:40px;flex-wrap:wrap;}
.section-head .lead{margin:0;max-width:520px;}

.grid{display:grid;gap:28px;}
.grid--3{grid-template-columns:repeat(3,1fr);}
.grid--4{grid-template-columns:repeat(4,1fr);}
.grid--2{grid-template-columns:repeat(2,1fr);}
@media (max-width: 980px){.grid--3,.grid--4{grid-template-columns:repeat(2,1fr);}}
@media (max-width: 620px){.grid--2,.grid--3,.grid--4{grid-template-columns:1fr;}}

/* ==========================================================================
   КАРТКИ
   ========================================================================== */
.card{
  background:var(--c-white);border-radius:var(--radius-m);overflow:hidden;
  border:1px solid var(--c-line);display:flex;flex-direction:column;height:100%;
  transition:transform .2s ease, box-shadow .2s ease;
}
.card:hover{transform:translateY(-4px);box-shadow:0 14px 30px -18px rgba(11,49,66,.35);}
.card-media{aspect-ratio:4/3;background:linear-gradient(135deg,var(--c-river) 0%,var(--c-deepwater) 100%);position:relative;}
.card-media svg{position:absolute;inset:0;width:100%;height:100%;}
.card-media--sand{background:linear-gradient(135deg,var(--c-sand) 0%,var(--c-copper) 130%);}
.card-body{padding:22px 22px 24px;display:flex;flex-direction:column;flex:1;}
.card-body h3{margin-bottom:10px;}
.card-body h3 a{color:var(--c-deepwater);}
.card-excerpt{color:var(--c-ink-soft);font-size:15px;margin-bottom:16px;flex:1;}
.card-meta{font-family:var(--f-mono);font-size:12px;color:var(--c-ink-soft);letter-spacing:.03em;}
.card-foot{margin-top:auto;padding-top:14px;border-top:1px solid var(--c-line);display:flex;justify-content:space-between;align-items:center;}

.price-tag{font-family:var(--f-display);font-size:20px;color:var(--c-copper-dark);}

/* ==========================================================================
   СТРІЧКА / БЛОГ
   ========================================================================== */
.post-list{display:flex;flex-direction:column;gap:36px;}
.post-row{display:grid;grid-template-columns:260px 1fr;gap:28px;padding-bottom:36px;border-bottom:1px solid var(--c-line);}
.post-row .card-media{aspect-ratio:4/3;border-radius:var(--radius-m);}
.post-row h2{font-size:24px;margin-bottom:10px;}
.post-row h2 a{color:var(--c-deepwater);}
@media (max-width:700px){.post-row{grid-template-columns:1fr;}}

.single .entry-content{font-size:18px;}
.single .entry-content h2{font-size:28px;margin-top:1.4em;}
.single .entry-content h3{font-size:21px;margin-top:1.2em;}
.single .entry-content blockquote{
  border-left:4px solid var(--c-copper);margin:1.6em 0;padding:.4em 0 .4em 24px;
  font-style:italic;color:var(--c-ink-soft);font-size:19px;
}
.single .entry-content ul,.single .entry-content ol{padding-left:1.4em;margin-bottom:1.2em;}
.single .entry-content img{border-radius:var(--radius-m);margin:1.4em 0;}
.entry-header{margin-bottom:30px;}
.entry-header .tag-row{margin-bottom:18px;}
.entry-cover{aspect-ratio:16/8;border-radius:var(--radius-m);margin-bottom:34px;overflow:hidden;}

/* ==========================================================================
   ШИРОКА ВІТРИНА / СІТКА АРХІВІВ
   ========================================================================== */
.archive-header{padding:var(--section-pad) 0 30px;background:var(--c-deepwater);color:var(--c-foam);}
.archive-header h1{color:var(--c-foam);}
.archive-header .lead{color:var(--c-sand);}
.filter-bar{display:flex;gap:10px;flex-wrap:wrap;margin-top:24px;}
.filter-bar a{
  font-family:var(--f-mono);font-size:12px;padding:6px 14px;border-radius:18px;
  border:1px solid rgba(250,247,240,.35);color:var(--c-sand);
}
.filter-bar a.is-active,.filter-bar a:hover{background:var(--c-copper);border-color:var(--c-copper);color:#fff;}

/* ==========================================================================
   ШАБЛОН FAQ
   ========================================================================== */
.faq-list{border-top:1px solid var(--c-line);}
.faq-item{border-bottom:1px solid var(--c-line);}
.faq-question{
  width:100%;text-align:left;background:none;border:none;padding:22px 0;
  display:flex;justify-content:space-between;align-items:center;gap:16px;
  font-family:var(--f-display);font-size:18px;text-transform:none;color:var(--c-deepwater);
}
.faq-question .plus{font-family:var(--f-mono);font-size:22px;color:var(--c-copper);transition:transform .2s ease;flex:0 0 auto;}
.faq-item.is-open .faq-question .plus{transform:rotate(45deg);}
.faq-answer{max-height:0;overflow:hidden;transition:max-height .25s ease;}
.faq-answer-inner{padding:0 0 22px;color:var(--c-ink-soft);}

/* ==========================================================================
   ШАБЛОН «АВТОРИ»
   ========================================================================== */
.author-card{display:flex;gap:18px;padding:24px;background:var(--c-white);border:1px solid var(--c-line);border-radius:var(--radius-m);}
.author-avatar{width:78px;height:78px;border-radius:50%;flex:0 0 auto;overflow:hidden;background:var(--c-river);}
.author-avatar img{width:100%;height:100%;object-fit:cover;}
.author-name{margin-bottom:4px;font-size:18px;}
.author-role{font-family:var(--f-mono);font-size:12px;color:var(--c-copper-dark);text-transform:uppercase;letter-spacing:.05em;margin-bottom:10px;display:block;}
.author-bio{color:var(--c-ink-soft);font-size:15px;margin-bottom:0;}

/* ==========================================================================
   КОНТАКТИ
   ========================================================================== */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start;}
.contact-info-item{display:flex;gap:16px;margin-bottom:26px;}
.contact-info-item .icon{width:40px;height:40px;flex:0 0 auto;color:var(--c-copper);}
.contact-info-item h4{margin-bottom:4px;font-size:15px;}
.contact-form input,.contact-form textarea{
  width:100%;border:1px solid var(--c-line);border-radius:var(--radius-s);
  padding:13px 16px;font-family:var(--f-body);font-size:15px;margin-bottom:16px;background:var(--c-white);
}
.contact-form label{display:block;font-family:var(--f-mono);font-size:12px;text-transform:uppercase;letter-spacing:.05em;margin-bottom:6px;color:var(--c-ink-soft);}
.contact-note{
  background:var(--c-sand-light);border:1px dashed var(--c-copper);border-radius:var(--radius-m);
  padding:16px 20px;font-size:14px;color:var(--c-ink-soft);margin-bottom:20px;
}
@media (max-width:780px){.contact-grid{grid-template-columns:1fr;}}

/* ==========================================================================
   САЙДБАР / ВІДЖЕТИ
   ========================================================================== */
.content-with-sidebar{display:grid;grid-template-columns:1fr 320px;gap:54px;}
@media (max-width:880px){.content-with-sidebar{grid-template-columns:1fr;}}
.widget{margin-bottom:38px;}
.widget-title,.widget .wp-block-heading{
  font-family:var(--f-display);font-size:16px;letter-spacing:.05em;text-transform:uppercase;
  padding-bottom:10px;border-bottom:2px solid var(--c-deepwater);margin-bottom:16px;color:var(--c-deepwater);
}
.widget ul{list-style:none;display:flex;flex-direction:column;gap:10px;}
.widget li a{color:var(--c-ink);font-size:15px;}
.widget li a:hover{color:var(--c-copper);}

/* block-based default widgets (search / latest posts / latest comments) */
.widget .wp-block-search__label{
  display:block;font-family:var(--f-mono);font-size:12px;text-transform:uppercase;letter-spacing:.05em;
  color:var(--c-ink-soft);margin-bottom:6px;
}
.widget .wp-block-search__inside-wrapper{display:flex;border:1px solid var(--c-line);border-radius:var(--radius-s);overflow:hidden;}
.widget .wp-block-search__input{border:none;padding:10px 12px;font-family:var(--f-body);font-size:14px;flex:1;min-width:0;}
.widget .wp-block-search__button{background:var(--c-deepwater);color:#fff;border:none;padding:0 16px;font-family:var(--f-display);text-transform:uppercase;font-size:12px;letter-spacing:.05em;}
.widget .wp-block-search__button:hover{background:var(--c-copper);}
.widget .wp-block-latest-posts__list,.widget .wp-block-latest-comments{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px;}
.widget .wp-block-latest-posts__list li,.widget .wp-block-latest-comments__comment{border-bottom:1px solid var(--c-line);padding-bottom:10px;}
.widget .wp-block-latest-posts__post-title,.widget .wp-block-latest-comments__comment-author,.widget .wp-block-latest-comments__comment-link{color:var(--c-ink);font-size:14px;}
.widget .wp-block-latest-comments__comment-meta{font-size:13px;color:var(--c-ink-soft);}
.widget .wp-block-group__inner-container > :last-child{margin-bottom:0;}

/* ==========================================================================
   ПАГІНАЦІЯ / КОМЕНТАРІ
   ========================================================================== */
.pagination{display:flex;gap:10px;margin-top:40px;flex-wrap:wrap;}
.pagination a,.pagination span{
  font-family:var(--f-mono);font-size:13px;padding:8px 14px;border:1px solid var(--c-line);border-radius:var(--radius-s);color:var(--c-deepwater);
}
.pagination .current{background:var(--c-deepwater);color:var(--c-foam);border-color:var(--c-deepwater);}

.comments-area{margin-top:60px;border-top:1px solid var(--c-line);padding-top:40px;}
.comment-list{list-style:none;}
.comment-body{padding:18px 0;border-bottom:1px solid var(--c-line);}
.comment-author{font-family:var(--f-display);font-size:14px;text-transform:uppercase;color:var(--c-deepwater);}
.comment-meta{font-family:var(--f-mono);font-size:12px;color:var(--c-ink-soft);margin-bottom:8px;}
.comment-respond input,.comment-respond textarea{
  width:100%;border:1px solid var(--c-line);border-radius:var(--radius-s);padding:12px 14px;margin-bottom:14px;font-family:var(--f-body);
}

/* ==========================================================================
   ПІДНІЖЖЯ
   ========================================================================== */
.site-footer{background:var(--c-deepwater);color:var(--c-sand);margin-top:80px;}
.footer-top{padding:64px 0 40px;}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:36px;}
.footer-grid h4{color:var(--c-foam);font-size:14px;letter-spacing:.06em;margin-bottom:16px;}
.footer-grid ul{list-style:none;display:flex;flex-direction:column;gap:9px;}
.footer-grid a{color:var(--c-sand);font-size:14px;}
.footer-grid a:hover{color:var(--c-copper);}
.footer-about p{color:rgba(232,220,194,.8);font-size:14px;}
.footer-social{display:flex;gap:12px;margin-top:16px;}
.footer-social a{
  width:36px;height:36px;border-radius:50%;border:1px solid rgba(232,220,194,.35);
  display:flex;align-items:center;justify-content:center;color:var(--c-sand);
}
.footer-social a:hover{background:var(--c-copper);border-color:var(--c-copper);color:#fff;}
.footer-bottom{
  border-top:1px solid rgba(232,220,194,.18);padding:22px 0;
  display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px;
  font-family:var(--f-mono);font-size:12px;color:rgba(232,220,194,.7);
}
@media (max-width:880px){.footer-grid{grid-template-columns:1fr 1fr;}}
@media (max-width:560px){.footer-grid{grid-template-columns:1fr;}}

/* ==========================================================================
   404 / ПОШУК
   ========================================================================== */
.error-404{padding:var(--section-pad) 0;text-align:center;}
.error-404 .eyebrow{justify-content:center;}
.error-404 .error-number{font-family:var(--f-display);font-size:clamp(80px,14vw,160px);color:var(--c-river-light);line-height:1;margin-bottom:0;}

/* ==========================================================================
   ДРУКОВАНІ ДОПОМІЖНІ КЛАСИ
   ========================================================================== */
.mt-0{margin-top:0;}
.text-center{text-align:center;}
.is-empty-state{padding:60px 0;text-align:center;color:var(--c-ink-soft);}
.skip-link{position:absolute;left:-9999px;}
.skip-link:focus{left:10px;top:10px;background:var(--c-copper);color:#fff;padding:10px 16px;z-index:999;}

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