/* ============================================================
   KERRAVE — theme.css
   WordPress-specific styles, front-page (Direction A) layout,
   blog/journal, gallery, contact and WooCommerce.
   Loads after kerrave-web.css (which holds the brand system).
   ============================================================ */

/* ---- skip link / a11y ---- */
.skip-link{position:absolute;left:-9999px;top:auto;z-index:100;background:var(--amber);color:var(--ink);
  padding:10px 16px;border-radius:6px;font-family:'Oswald';font-weight:600;}
.skip-link:focus{left:16px;top:12px;}
.screen-reader-text{position:absolute!important;width:1px;height:1px;overflow:hidden;clip:rect(1px,1px,1px,1px);}

/* ---- admin bar offset ---- */
.admin-bar .kr-nav{top:32px;}
@media (max-width:782px){.admin-bar .kr-nav{top:46px;}}

/* mobile nav toggle */
.kr-nav .menu-toggle{display:none;background:none;border:1px solid var(--line);border-radius:6px;
  color:var(--cream);padding:8px 12px;cursor:pointer;font-size:18px;line-height:1;}
.kr-nav .nav-cart{display:inline-flex;align-items:center;gap:8px;color:var(--amber-soft);text-decoration:none;
  font-family:'Oswald';font-weight:600;text-transform:uppercase;letter-spacing:.1em;font-size:12px;}

/* ============================================================
   FRONT PAGE — Direction A (immersive)
   ============================================================ */
.heroA{min-height:92vh;display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;padding:120px var(--gut) 80px;position:relative;}
.heroA .logo{width:clamp(150px,18vw,230px);height:auto;
  filter:drop-shadow(0 .2em .9em rgba(0,0,0,.6)) drop-shadow(0 0 1.6em rgba(255,175,80,.28));
  animation:floatA 7s ease-in-out infinite;}
@keyframes floatA{0%,100%{transform:translateY(0);}50%{transform:translateY(-12px);}}
@media (prefers-reduced-motion:reduce){.heroA .logo{animation:none;}}
.heroA h1{font-size:clamp(56px,13vw,170px);margin:18px 0 6px;}
.heroA .eyebrow{margin-bottom:8px;}
.heroA .sub{font-family:'Oswald';font-weight:300;text-transform:uppercase;letter-spacing:.42em;
  font-size:clamp(12px,1.5vw,16px);color:rgba(244,236,216,.66);margin-top:6px;}
.heroA .cta{display:flex;gap:16px;flex-wrap:wrap;justify-content:center;margin-top:38px;}
.heroA .scroll{position:absolute;bottom:30px;left:50%;transform:translateX(-50%);
  font-family:'Oswald';text-transform:uppercase;letter-spacing:.3em;font-size:11px;
  color:rgba(244,236,216,.5);display:flex;flex-direction:column;align-items:center;gap:8px;}
.heroA .scroll::after{content:"";width:1px;height:34px;background:linear-gradient(var(--amber),transparent);}

.featA{display:grid;grid-template-columns:1.1fr .9fr;gap:40px;align-items:center;}
.featA .media{min-height:380px;}
.featA .media img,.featA .media video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
.featA .body .when{font-family:'Bungee';font-size:clamp(30px,4vw,54px);color:var(--cream);margin:10px 0;}
.featA .body p{margin:16px 0 26px;max-width:46ch;}
.featA .body .row{display:flex;gap:28px;margin-bottom:26px;flex-wrap:wrap;}
.featA .body .row .k{font-family:'Oswald';font-weight:700;text-transform:uppercase;letter-spacing:.16em;
  font-size:11px;color:var(--amber);}
.featA .body .row .v{font-family:'Audiowide';font-size:16px;}

.galA{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:150px;gap:14px;}
.galA .kr-media:nth-child(1){grid-column:span 2;grid-row:span 2;}
.galA .kr-media:nth-child(4){grid-column:span 2;}
.galA .kr-media img,.galA .kr-media video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}

@media (max-width:860px){.featA{grid-template-columns:1fr;}.galA{grid-template-columns:repeat(2,1fr);}}

/* media element fills */
.kr-media img,.kr-media video{display:block;}
.kr-media.has-img .tag,.kr-media.has-img .play.is-decor{display:none;}

/* ============================================================
   PAGE HEADER (interior pages / archives)
   ============================================================ */
.kr-pagehead{padding:130px var(--gut) 40px;text-align:center;}
.kr-pagehead .kr-eyebrow{display:block;margin-bottom:10px;}
.kr-pagehead h1{font-size:clamp(34px,6vw,72px);}
.kr-pagehead p{max-width:60ch;margin:16px auto 0;}
.kr-breadcrumb{font-family:'Oswald';text-transform:uppercase;letter-spacing:.14em;font-size:12px;
  color:rgba(244,236,216,.5);margin-bottom:16px;}
.kr-breadcrumb a{color:var(--amber-soft);text-decoration:none;}

/* ============================================================
   ARTICLE / BLOG (Journal)
   ============================================================ */
.kr-postgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
@media (max-width:900px){.kr-postgrid{grid-template-columns:1fr 1fr;}}
@media (max-width:600px){.kr-postgrid{grid-template-columns:1fr;}}
.kr-postcard{display:flex;flex-direction:column;border:1px solid var(--line);border-radius:14px;overflow:hidden;
  background:var(--card);text-decoration:none;color:var(--cream);transition:transform .2s ease, box-shadow .25s ease;}
.kr-postcard:hover{transform:translateY(-4px);box-shadow:0 .5em 2em -.6em rgba(0,0,0,.6);border-color:rgba(244,176,74,.4);}
.kr-postcard .pic{position:relative;aspect-ratio:16/10;}
.kr-postcard .pic .kr-media{position:absolute;inset:0;border:none;border-radius:0;min-height:0;}
.kr-postcard .pad{padding:20px 22px 24px;display:flex;flex-direction:column;gap:8px;flex:1;}
.kr-postcard .cat{font-family:'Oswald';font-weight:700;text-transform:uppercase;letter-spacing:.16em;
  font-size:11px;color:var(--amber);}
.kr-postcard h3{font-family:'Audiowide';font-size:20px;line-height:1.25;}
.kr-postcard .ex{color:rgba(244,236,216,.7);font-size:14px;}
.kr-postcard .date{margin-top:auto;font-family:'Oswald';font-weight:300;text-transform:uppercase;
  letter-spacing:.1em;font-size:12px;color:rgba(244,236,216,.5);}

/* single article */
.kr-article{max-width:760px;margin:0 auto;}
.kr-article .kr-media{margin-bottom:32px;}
.kr-article .entry-content{font-size:18px;line-height:1.75;}
.kr-article .entry-content > *{margin-bottom:1.1em;}
.kr-article .entry-content h2{font-family:'Bungee';font-size:30px;margin:1.4em 0 .5em;}
.kr-article .entry-content h3{font-family:'Audiowide';font-size:23px;margin:1.2em 0 .4em;color:var(--amber-soft);}
.kr-article .entry-content a{color:var(--amber);text-underline-offset:3px;}
.kr-article .entry-content blockquote{border-left:3px solid var(--amber);padding:6px 0 6px 22px;margin:1.4em 0;
  font-family:'Audiowide';font-size:20px;color:var(--cream);}
.kr-article .entry-content img{border-radius:12px;max-width:100%;height:auto;}
.kr-article .entry-content ul,.kr-article .entry-content ol{padding-left:1.3em;}
.kr-article .entry-content li{margin-bottom:.5em;}
.kr-article .entry-content code{background:rgba(8,5,18,.6);padding:2px 6px;border-radius:4px;font-size:.9em;}

/* meta + tags */
.kr-postmeta{display:flex;flex-wrap:wrap;gap:16px;align-items:center;justify-content:center;
  font-family:'Oswald';text-transform:uppercase;letter-spacing:.12em;font-size:12px;
  color:rgba(244,236,216,.6);margin-top:18px;}
.kr-tags{display:flex;flex-wrap:wrap;gap:10px;margin-top:30px;}
.kr-tags a{font-family:'Oswald';font-size:12px;text-transform:uppercase;letter-spacing:.1em;
  color:var(--amber-soft);text-decoration:none;border:1px solid var(--line);border-radius:999px;padding:6px 14px;}
.kr-tags a:hover{border-color:var(--amber);}

/* pagination */
.kr-pagination{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin-top:48px;}
.kr-pagination a,.kr-pagination span{font-family:'Oswald';font-weight:600;color:var(--cream);text-decoration:none;
  border:1px solid var(--line);border-radius:8px;padding:10px 16px;min-width:44px;text-align:center;}
.kr-pagination .current{background:var(--amber);color:var(--ink);border-color:var(--amber);}
.kr-pagination a:hover{border-color:var(--amber);}

/* ============================================================
   SINGLE EVENT
   ============================================================ */
.kr-event-hero{position:relative;min-height:60vh;display:flex;align-items:flex-end;
  padding:150px var(--gut) 56px;overflow:hidden;}
.kr-event-hero .bgimg{position:absolute;inset:0;z-index:-1;}
.kr-event-hero .bgimg img,.kr-event-hero .bgimg video{width:100%;height:100%;object-fit:cover;}
.kr-event-hero .bgimg::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(8,5,18,.35),rgba(8,5,18,.92));}
.kr-event-hero .inner{max-width:var(--maxw);margin:0 auto;width:100%;}
.kr-event-hero .when{font-family:'Oswald';font-weight:600;text-transform:uppercase;letter-spacing:.2em;
  color:var(--amber);font-size:14px;margin-bottom:10px;}
.kr-event-hero h1{font-size:clamp(36px,7vw,84px);}
.kr-event-detail{display:grid;grid-template-columns:1.4fr .8fr;gap:48px;align-items:start;}
@media (max-width:860px){.kr-event-detail{grid-template-columns:1fr;}}
.kr-ticketbox{border:1.6px solid var(--amber);border-radius:14px;padding:28px;background:var(--card);
  box-shadow:0 0 1.6em -.5em var(--amber);position:sticky;top:100px;}
.kr-ticketbox .price{font-family:'Bungee';font-size:42px;color:var(--cream);line-height:1;}
.kr-ticketbox .price small{font-family:'Oswald';font-weight:300;font-size:14px;color:rgba(244,236,216,.6);
  display:block;text-transform:uppercase;letter-spacing:.12em;margin-bottom:8px;}
.kr-ticketbox .kr-btn{width:100%;justify-content:center;margin-top:18px;}
.kr-ticketbox .note{font-size:13px;color:rgba(244,236,216,.6);margin-top:14px;text-align:center;}
.kr-factrow{display:flex;flex-direction:column;gap:0;margin:8px 0 24px;}
.kr-factrow .f{display:flex;justify-content:space-between;gap:16px;padding:14px 0;border-bottom:1px solid var(--line);}
.kr-factrow .f .k{font-family:'Oswald';font-weight:700;text-transform:uppercase;letter-spacing:.14em;
  font-size:12px;color:var(--amber);}
.kr-factrow .f .v{font-family:'Audiowide';font-size:15px;text-align:right;}
.kr-soldout{display:inline-block;font-family:'Oswald';font-weight:700;text-transform:uppercase;letter-spacing:.16em;
  font-size:12px;color:var(--c3);border:1px solid var(--c3);border-radius:999px;padding:6px 14px;margin-bottom:12px;}
.kr-event.past{opacity:.6;}

/* ============================================================
   GALLERY page
   ============================================================ */
.kr-gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;}
@media (max-width:760px){.kr-gallery-grid{grid-template-columns:1fr 1fr;}}
.kr-gallery-grid a{display:block;position:relative;aspect-ratio:1;border-radius:12px;overflow:hidden;border:1px solid var(--line);}
.kr-gallery-grid img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease;}
.kr-gallery-grid a:hover img{transform:scale(1.05);}

/* ============================================================
   CONTACT page
   ============================================================ */
.kr-contact{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start;}
@media (max-width:860px){.kr-contact{grid-template-columns:1fr;}}
.kr-form{display:flex;flex-direction:column;gap:14px;}
.kr-form label{font-family:'Oswald';font-weight:600;text-transform:uppercase;letter-spacing:.12em;
  font-size:12px;color:var(--amber);}
.kr-form input,.kr-form textarea{font-family:'Oswald';font-size:15px;color:var(--cream);
  background:rgba(8,5,18,.6);border:1px solid var(--line);border-radius:8px;padding:13px 14px;outline:none;width:100%;}
.kr-form input:focus,.kr-form textarea:focus{border-color:var(--amber);}
.kr-form textarea{min-height:150px;resize:vertical;}
.kr-contact .info p{margin-bottom:16px;}
.kr-contact .info .li{display:flex;gap:12px;align-items:flex-start;margin-bottom:14px;}
.kr-contact .info .li .k{font-family:'Oswald';font-weight:700;text-transform:uppercase;letter-spacing:.14em;
  font-size:12px;color:var(--amber);min-width:90px;}

/* ============================================================
   COMMENTS
   ============================================================ */
.kr-comments{max-width:760px;margin:56px auto 0;}
.kr-comments h3{font-family:'Bungee';font-size:24px;margin-bottom:24px;}
.kr-comments ol{list-style:none;}
.kr-comments .comment{border:1px solid var(--line);border-radius:12px;padding:18px 20px;margin-bottom:16px;
  background:var(--card);}
.kr-comments .comment .author{font-family:'Audiowide';font-size:15px;}
.kr-comments .comment .date{font-size:12px;color:rgba(244,236,216,.5);text-transform:uppercase;letter-spacing:.1em;}
.kr-comments .children{list-style:none;margin-top:16px;padding-left:24px;border-left:1px solid var(--line);}

/* ============================================================
   WooCommerce (light touch — inherits Woo base, restyles key bits)
   ============================================================ */
.woocommerce-page .kr-wrap, .woocommerce .kr-wrap{color:var(--cream);}
.woocommerce ul.products li.product,.woocommerce-page ul.products li.product{
  background:var(--card);border:1px solid var(--line);border-radius:14px;padding:16px;text-align:center;}
.woocommerce ul.products li.product .price{color:var(--amber-soft);font-family:'Bungee';}
.woocommerce ul.products li.product h2,.woocommerce ul.products li.product .woocommerce-loop-product__title{
  font-family:'Audiowide'!important;font-size:18px!important;color:var(--cream);}
.woocommerce span.onsale{background:var(--amber);color:var(--ink);font-family:'Oswald';font-weight:700;}
.woocommerce #respond input#submit,.woocommerce a.button,.woocommerce button.button,.woocommerce input.button,
.woocommerce #respond input#submit.alt,.woocommerce a.button.alt,.woocommerce button.button.alt,.woocommerce input.button.alt{
  font-family:'Oswald';font-weight:600;text-transform:uppercase;letter-spacing:.12em;
  background:linear-gradient(180deg,var(--amber-soft),var(--amber));color:var(--ink);border-radius:6px;
  border:1.6px solid var(--amber);}
.woocommerce #respond input#submit:hover,.woocommerce a.button:hover,.woocommerce button.button:hover,
.woocommerce input.button:hover{background:var(--amber-soft);}
.woocommerce div.product p.price,.woocommerce div.product span.price{color:var(--amber-soft);font-family:'Bungee';}
.woocommerce .woocommerce-message,.woocommerce .woocommerce-info,.woocommerce .woocommerce-error{
  border-top-color:var(--amber);background:var(--card);color:var(--cream);}
.woocommerce-store-notice,p.demo_store{background:var(--bg2);color:var(--cream);}
.woocommerce table.shop_table,.woocommerce-cart table.cart{border-color:var(--line);}
.woocommerce form .form-row input.input-text,.woocommerce form .form-row textarea,.select2-container .select2-selection{
  background:rgba(8,5,18,.6);border:1px solid var(--line);color:var(--cream);border-radius:6px;}

/* links inside Woo content (category meta, tags, breadcrumb, tabs, reviews) */
.woocommerce a:not(.button):not(.kr-btn):not(.add_to_cart_button),
.woocommerce-breadcrumb a,
.woocommerce-page a:not(.button):not(.kr-btn){
  color:var(--amber-soft);text-decoration:none;}
.woocommerce a:not(.button):not(.kr-btn):not(.add_to_cart_button):hover,
.woocommerce-breadcrumb a:hover,
.woocommerce-page a:not(.button):not(.kr-btn):hover{
  color:var(--cream);text-decoration:underline;text-underline-offset:3px;}
.woocommerce .product_meta{font-family:'Oswald';font-size:14px;color:rgba(244,236,216,.7);}
.woocommerce .product_meta .posted_in,.woocommerce .product_meta .tagged_as{color:rgba(244,236,216,.7);}
.woocommerce-breadcrumb{font-family:'Oswald';text-transform:uppercase;letter-spacing:.1em;
  font-size:12px;color:rgba(244,236,216,.55);margin-bottom:18px;}

/* product tabs (Description / Reviews) — replace Woo's grey-on-grey */
.woocommerce div.product .woocommerce-tabs ul.tabs{padding:0;margin:0 0 0 0;display:flex;flex-wrap:wrap;gap:8px;
  border-bottom:1px solid var(--line);list-style:none;}
.woocommerce div.product .woocommerce-tabs ul.tabs::before{display:none;}
.woocommerce div.product .woocommerce-tabs ul.tabs li{background:transparent;border:none;border-radius:8px 8px 0 0;
  margin:0;padding:0;list-style:none;}
.woocommerce div.product .woocommerce-tabs ul.tabs li::marker{content:"";color:transparent;}
.woocommerce div.product .woocommerce-tabs ul.tabs li::before,
.woocommerce div.product .woocommerce-tabs ul.tabs li::after{display:none;}
.woocommerce div.product .woocommerce-tabs ul.tabs li a{font-family:'Oswald';font-weight:600;text-transform:uppercase;
  letter-spacing:.12em;font-size:13px;color:rgba(244,236,216,.6);padding:14px 20px;display:block;
  border:1px solid transparent;border-bottom:none;border-radius:8px 8px 0 0;transition:color .2s,background .2s;}
.woocommerce div.product .woocommerce-tabs ul.tabs li a:hover{color:var(--cream);}
.woocommerce div.product .woocommerce-tabs ul.tabs li.active{background:var(--card);}
.woocommerce div.product .woocommerce-tabs ul.tabs li.active a{color:var(--amber);
  border-color:var(--line);background:var(--card);}
.woocommerce div.product .woocommerce-tabs .panel{color:rgba(244,236,216,.85);font-size:16px;line-height:1.7;
  background:var(--card);border:1px solid var(--line);border-top:none;border-radius:0 0 12px 12px;
  padding:26px 28px;margin-top:0;}
.woocommerce div.product .woocommerce-tabs .panel h2{font-family:'Audiowide';font-weight:400;font-size:22px;
  color:var(--cream);margin-bottom:14px;}
.woocommerce div.product .woocommerce-tabs .panel p{color:rgba(244,236,216,.85);margin-bottom:1em;}
.woocommerce div.product .woocommerce-tabs .panel a{color:var(--amber-soft);}
.woocommerce #reviews #comments h2,.woocommerce #reviews h3{color:var(--cream);font-family:'Audiowide';font-weight:400;}
.woocommerce #reviews #comments ol.commentlist li .comment-text{background:rgba(8,5,18,.4);border:1px solid var(--line);
  border-radius:10px;color:rgba(244,236,216,.85);}
.woocommerce #reviews #comments ol.commentlist li .comment-text .meta{color:var(--amber-soft);}
.woocommerce #review_form #respond textarea,.woocommerce #review_form #respond input[type=text],
.woocommerce #review_form #respond input[type=email]{background:rgba(8,5,18,.6);border:1px solid var(--line);
  color:var(--cream);border-radius:6px;padding:12px 14px;}
.woocommerce #review_form #respond label{color:var(--amber);font-family:'Oswald';font-weight:600;}
.woocommerce .star-rating span,.woocommerce p.stars a{color:var(--amber);}

/* ============================================================
   SEARCH / 404
   ============================================================ */
.kr-center{max-width:640px;margin:0 auto;text-align:center;}
.kr-404 .big{font-family:'Bungee';font-size:clamp(80px,18vw,200px);color:var(--cream);line-height:.9;
  text-shadow:0 0 .6em rgba(244,176,74,.25);}
.kr-searchform{display:flex;gap:10px;margin-top:24px;justify-content:center;flex-wrap:wrap;}
.kr-searchform input[type=search]{font-family:'Oswald';font-size:15px;color:var(--cream);background:rgba(8,5,18,.6);
  border:1px solid var(--line);border-radius:8px;padding:13px 16px;min-width:240px;outline:none;}
.kr-searchform input[type=search]:focus{border-color:var(--amber);}

/* ============================================================
   RESPONSIVE NAV
   ============================================================ */
@media (max-width:860px){
  .kr-nav .menu-toggle{display:block;}
  .kr-nav .links{position:absolute;top:100%;left:0;right:0;flex-direction:column;gap:0;align-items:stretch;
    background:rgba(8,5,18,.97);border-top:1px solid var(--line);padding:8px 0;display:none;}
  .kr-nav .links.open{display:flex;}
  .kr-nav .links a{padding:14px var(--gut);}
  .kr-nav .links a::after{display:none;}
}
