/*
Theme Name: Chaos Packaging
Theme URI: https://littleredjet.com/
Author: Little Red Jet
Author URI: https://littleredjet.com/
Description: Unconventional packaging directory. A custom theme with editable Collections and Locations taxonomies, a Brand listings post type (one-liner, description, link, image, sponsored flag), Contact Form 7 integration for the contact / submit / subscribe forms, and a live search overlay.
Version: 1.0.1
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: chaos-packaging
*/

/* ===== CHAOS PACKAGING — STYLES ===== */
:root{
  --bg:#ffffff;
  --ink:#111111;
  --muted:#6b6b6b;
  --line:#ececec;
  --chip:#f4f4f4;
  --chip-hover:#ebebeb;
  --card:#f6f6f6;
  --radius:18px;
  --maxw:1180px;
  --serif:"Hedvig Letters Serif", Georgia, "Times New Roman", serif;
  --sans:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
}

*{box-sizing:border-box;}
html{-webkit-text-size-adjust:100%;}
body{
  margin:0;
  background:var(--bg);
  color:var(--ink);
  font-family:var(--sans);
  font-size:16px;
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
}
a{color:inherit;text-decoration:none;}
img{max-width:100%;display:block;}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px;}

/* ---------- Header ---------- */
.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(255,255,255,.85);
  backdrop-filter:saturate(180%) blur(12px);
  border-bottom:1px solid var(--line);
}
.site-header .wrap{
  display:flex;align-items:center;justify-content:space-between;
  height:84px;
}
.logo{display:inline-flex;align-items:center;}
.logo svg{height:40px;width:auto;display:block;}
.logo img{height:46px;width:auto;display:block;}
/* CSS wordmark recreation of the CHAOS logo (used when no logo image supplied) */
.wordmark{
  font-family:"Fredoka","Arial Rounded MT Bold",Verdana,var(--sans);
  font-weight:700;font-size:42px;line-height:1;letter-spacing:-1px;
  display:inline-flex;align-items:center;
}
.wordmark span{display:inline-block;transform-origin:center;}
.wordmark .c0{color:#F24A3B;transform:rotate(-7deg) translateY(1px);}
.wordmark .c1{color:#F47C20;transform:rotate(4deg);}
.wordmark .c2{color:#F6B22A;transform:rotate(-4deg) translateY(1px);}
.wordmark .c3{color:#25B15C;transform:rotate(6deg);}
.wordmark .c4{color:#1C46C2;transform:rotate(-5deg) translateY(1px);}
.site-footer .wordmark{font-size:34px;}
.header-actions{display:flex;align-items:center;gap:12px;}
.icon-btn{
  width:44px;height:44px;border-radius:50%;
  border:1px solid var(--line);background:#fafafa;
  display:inline-flex;align-items:center;justify-content:center;
  cursor:pointer;transition:background .15s ease;
}
.icon-btn:hover{background:var(--chip-hover);}
.icon-btn svg{width:18px;height:18px;}

/* ---------- Hero ---------- */
.hero{padding:64px 0 8px;}
.hero h1{
  font-family:var(--serif);
  font-weight:500;
  font-size:clamp(24px,3.6vw,44px);
  line-height:1.18;
  letter-spacing:-.01em;
  margin:0 0 36px;
}
.hero h1 span{display:block;white-space:nowrap;}
.hero h1 .accent{font-style:italic;color:var(--muted);}

/* subscribe */
.subscribe{
  display:flex;gap:10px;flex-wrap:wrap;align-items:center;
  background:var(--chip);
  border-radius:999px;
  padding:8px;
  max-width:560px;
}
.subscribe input{
  flex:1;min-width:180px;border:0;background:transparent;
  font-size:16px;padding:12px 16px;color:var(--ink);outline:none;
}
.subscribe input::placeholder{color:#9a9a9a;}
.btn-dark{
  border:0;cursor:pointer;
  background:var(--ink);color:#fff;
  font-weight:600;font-size:15px;
  padding:13px 22px;border-radius:999px;
  display:inline-flex;align-items:center;gap:8px;
  transition:opacity .15s ease;
}
.btn-dark:hover{opacity:.88;}
.subscribe-note{color:var(--muted);font-size:14px;margin:14px 2px 0;}

/* ---------- Category chips ---------- */
.filters{display:flex;flex-wrap:wrap;gap:10px;padding:48px 0 28px;}
.chip{
  border:1px solid var(--line);background:var(--chip);
  color:var(--ink);font-size:14px;font-weight:500;
  padding:9px 16px;border-radius:999px;cursor:pointer;
  transition:background .15s ease,border-color .15s ease;
}
.chip:hover{background:var(--chip-hover);}
.chip.active{background:var(--ink);color:#fff;border-color:var(--ink);}

/* ---------- Grid ---------- */
.grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:28px 24px;
  padding-bottom:80px;
}
.card{display:block;cursor:pointer;}
.card .thumb{
  border-radius:var(--radius);
  overflow:hidden;background:var(--card);
  aspect-ratio:16/11;border:1px solid var(--line);
}
.card .thumb img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .4s ease;
}
.card:hover .thumb img{transform:scale(1.03);}
.card .meta{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 4px 0;}
.card .name{font-weight:600;font-size:16px;}
.card .tag{
  font-size:12.5px;color:var(--muted);
  background:var(--chip);border-radius:999px;
  padding:5px 11px;white-space:nowrap;
}

/* ---------- Section heading ---------- */
.section-head{
  display:flex;align-items:center;justify-content:space-between;
  padding:8px 0 28px;gap:16px;
}
.section-head h2{font-size:26px;font-weight:700;margin:0;}
.view-all{
  border:1px solid var(--line);background:#fff;
  padding:11px 18px;border-radius:999px;font-weight:600;font-size:14px;
  display:inline-flex;align-items:center;gap:8px;cursor:pointer;
  transition:background .15s ease;
}
.view-all:hover{background:var(--chip);}

/* ---------- Listing detail ---------- */
.detail{padding:24px 0 40px;}
.detail .hero-img{
  border-radius:24px;overflow:hidden;border:1px solid var(--line);
  background:var(--card);margin-bottom:36px;
}
.detail .hero-img img{width:100%;display:block;}
.detail h1{font-family:var(--serif);font-weight:500;font-size:clamp(34px,5vw,52px);margin:0 0 18px;}
.detail .lead{font-size:20px;color:#222;max-width:62ch;margin:0 0 18px;line-height:1.45;}
.detail .about{font-size:16px;color:#555;max-width:62ch;margin:0 0 28px;line-height:1.7;}
.detail-meta{display:flex;flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:8px;}
.pill{background:var(--chip);border-radius:999px;padding:8px 15px;font-size:14px;color:var(--muted);}

/* ---------- Footer ---------- */
.site-footer{border-top:1px solid var(--line);padding:48px 0;margin-top:40px;}
.site-footer .wrap{display:flex;flex-wrap:wrap;gap:20px;align-items:center;justify-content:space-between;}
.site-footer .muted{color:var(--muted);font-size:14px;}
.footer-links{display:flex;gap:22px;flex-wrap:wrap;}
.footer-links a{color:var(--muted);font-size:14px;}
.footer-links a:hover{color:var(--ink);}

/* breadcrumb */
.crumbs{padding:24px 0 0;color:var(--muted);font-size:14px;}
.crumbs a:hover{color:var(--ink);text-decoration:underline;}

/* empty state */
.empty{padding:60px 0;color:var(--muted);font-size:17px;}

/* ---------- Header nav (inline, next to logo) ---------- */
.nav-links{display:flex;align-items:center;gap:26px;margin-right:8px;}
.nav-links a,.nav-drop-btn{
  font-size:15px;font-weight:500;color:#333;white-space:nowrap;
  background:none;border:0;padding:0;cursor:pointer;
  font-family:inherit;display:inline-flex;align-items:center;gap:6px;
}
.nav-links a:hover,.nav-drop-btn:hover{color:var(--ink);}
.menu-btn{display:none;}

/* View All Collections dropdown */
.dropdown{position:relative;}
.nav-drop-btn .caret{width:15px;height:15px;transition:transform .15s ease;}
.dropdown.open .nav-drop-btn .caret{transform:rotate(180deg);}
.dropdown-menu{
  position:absolute;top:calc(100% + 16px);left:50%;transform:translateX(-50%);
  min-width:230px;background:#fff;border:1px solid var(--line);border-radius:14px;
  box-shadow:0 18px 50px rgba(0,0,0,.12);padding:8px;display:none;z-index:60;
}
.dropdown.open .dropdown-menu,.dropdown:hover .dropdown-menu{display:block;}
.dropdown-menu::before{content:"";position:absolute;top:-16px;left:0;right:0;height:16px;}
.dropdown-menu a{display:block;padding:10px 12px;border-radius:9px;font-size:14px;color:#333;}
.dropdown-menu a:hover{background:var(--chip);color:var(--ink);}

/* mobile slide-down menu */
.mobile-menu{
  display:none;border-bottom:1px solid var(--line);background:#fff;
}
.mobile-menu.open{display:block;}
.mobile-menu .wrap{display:flex;flex-direction:column;padding:14px 24px 22px;gap:4px;}
.mobile-menu a{padding:12px 4px;font-size:17px;font-weight:500;border-bottom:1px solid var(--line);}
.mobile-menu a:last-child{border-bottom:0;}

/* ---------- Socials ---------- */
.socials{display:flex;gap:10px;}
.socials a{
  width:40px;height:40px;border-radius:50%;border:1px solid var(--line);
  background:#fafafa;display:inline-flex;align-items:center;justify-content:center;
  color:var(--muted);transition:background .15s ease,color .15s ease;
}
.socials a:hover{background:var(--ink);color:#fff;}
.socials svg{width:18px;height:18px;}

/* ---------- Search overlay ---------- */
.search-overlay{
  position:fixed;inset:0;z-index:100;display:none;
  background:rgba(20,20,20,.45);backdrop-filter:blur(4px);
}
.search-overlay.open{display:block;}
.search-panel{
  max-width:680px;margin:8vh auto 0;background:#fff;border-radius:22px;
  box-shadow:0 24px 80px rgba(0,0,0,.25);overflow:hidden;
}
.search-bar{display:flex;align-items:center;gap:12px;padding:18px 22px;border-bottom:1px solid var(--line);}
.search-bar svg{width:22px;height:22px;color:var(--muted);flex:none;}
.search-bar input{flex:1;border:0;outline:none;font-size:20px;font-family:var(--sans);color:var(--ink);}
.search-bar .esc{font-size:12px;color:var(--muted);border:1px solid var(--line);border-radius:7px;padding:3px 8px;}
.search-results{max-height:56vh;overflow:auto;padding:8px;}
.search-results .res{display:flex;align-items:center;gap:14px;padding:10px 12px;border-radius:14px;}
.search-results .res:hover{background:var(--chip);}
.search-results .res img{width:64px;height:44px;object-fit:cover;border-radius:9px;border:1px solid var(--line);flex:none;}
.search-results .res .rn{font-weight:600;}
.search-results .res .rc{font-size:13px;color:var(--muted);}
.search-results .none{padding:26px 14px;color:var(--muted);}
.search-hint{padding:18px 22px;color:var(--muted);font-size:14px;}

/* ---------- Page header (simple pages) ---------- */
.page-head{padding:56px 0 8px;max-width:720px;}
.page-head h1{font-family:var(--serif);font-weight:500;font-size:clamp(32px,5vw,52px);margin:0 0 18px;line-height:1.1;}
.page-head p{font-size:18px;color:#444;margin:0;}

/* ---------- Forms ---------- */
.form{max-width:620px;padding:36px 0 80px;display:grid;gap:18px;}
.field{display:grid;gap:7px;}
.field label{font-size:14px;font-weight:600;}
.field input,.field select,.field textarea{
  font-family:var(--sans);font-size:16px;color:var(--ink);
  border:1px solid var(--line);background:#fafafa;border-radius:12px;
  padding:13px 15px;outline:none;transition:border-color .15s ease,background .15s ease;
}
.field input:focus,.field select:focus,.field textarea:focus{border-color:#bdbdbd;background:#fff;}
.field textarea{min-height:130px;resize:vertical;}
.form .row{display:grid;grid-template-columns:1fr 1fr;gap:18px;}
.form-note{color:var(--muted);font-size:14px;margin-top:2px;}
.form .btn-dark{justify-self:start;padding:15px 28px;font-size:16px;}

/* sponsor / contact split layout */
.split{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start;padding:36px 0 80px;}
.split h2{font-size:24px;margin:0 0 18px;}
.split .form{padding:0;max-width:none;}
.split .tiers{grid-template-columns:1fr;padding:0;}

/* sponsor tiers */
.tiers{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;padding:14px 0 40px;}
.tier{border:1px solid var(--line);border-radius:18px;padding:26px 24px;background:#fafafa;}
.tier h3{margin:0 0 6px;font-size:19px;}
.tier .price{font-family:var(--serif);font-size:30px;margin:0 0 14px;}
.tier ul{margin:0;padding-left:18px;color:#444;font-size:15px;line-height:1.7;}

.success{
  border:1px solid #cdeccd;background:#f1faf1;color:#1f6b32;
  border-radius:14px;padding:16px 18px;font-size:15px;
}

/* ---------- Responsive ---------- */
@media (max-width:900px){
  .grid{grid-template-columns:repeat(2,1fr);}
  .hero{padding:44px 0 8px;}
  .nav-links{display:none;}
  .menu-btn{display:inline-flex;}
  .tiers{grid-template-columns:1fr;}
  .split{grid-template-columns:1fr;gap:48px;}
}
@media (max-width:560px){
  .grid{grid-template-columns:1fr;}
  .site-header .wrap{height:72px;}
  .wordmark{font-size:34px;}
  .section-head h2{font-size:22px;}
  .form .row{grid-template-columns:1fr;}
  .site-footer .wrap{flex-direction:column;align-items:flex-start;}
  .hero h1 span{white-space:normal;}
}

/* =====================================================================
 * WordPress + Contact Form 7 integration
 * ===================================================================== */
.site-main{display:block;}

/* page subtitle on archives */
.page-sub{color:var(--muted);max-width:62ch;margin:8px 0 0;font-size:16px;}

/* ---- Subscribe form (CF7) on the home hero ---- */
.subscribe-wrap{margin-top:8px;}
.subscribe-wrap form.wpcf7-form{
  display:flex;gap:10px;flex-wrap:wrap;align-items:center;
  background:var(--chip);border-radius:999px;padding:8px;max-width:560px;margin:0;
}
.subscribe-wrap form.wpcf7-form > p{margin:0;display:flex;flex:1;gap:10px;align-items:center;flex-wrap:wrap;}
.subscribe-wrap .wpcf7-form-control-wrap{flex:1;min-width:180px;}
.subscribe-wrap input[type=email]{
  width:100%;flex:1;min-width:180px;border:0;background:transparent;
  font-size:16px;padding:12px 16px;color:var(--ink);outline:none;
}
.subscribe-wrap input[type=email]::placeholder{color:#9a9a9a;}
.subscribe-wrap input[type=submit]{
  border:0;cursor:pointer;background:var(--ink);color:#fff;font-weight:600;font-size:15px;
  padding:13px 24px;border-radius:999px;transition:opacity .15s ease;
}
.subscribe-wrap input[type=submit]:hover{opacity:.88;}
.subscribe-wrap .wpcf7-spinner{margin:0 6px;}

/* ---- Contact / Submit forms (CF7) inside .form ---- */
.form--narrow{max-width:620px;}
.form label{font-size:14px;font-weight:600;display:block;}
.form .wpcf7-form-control-wrap{display:block;}

/* Contact Form 7 wraps each row in a <p> and puts a <br> between the
   label and the input. Normalise that so labels sit tight above their
   fields and every field is evenly spaced. */
.form .wpcf7-form > p{margin:0 0 18px;}       /* bare rows e.g. the submit button */
.form .field{margin:0 0 18px;}
.form .field > p{margin:0;}                   /* remove CF7's inner <p> margin */
.form .field br{display:none;}                /* drop the label/input line break */
.form .field label{display:block;margin:0 0 7px;}
.form .row{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin:0 0 18px;}
.form .row .field{margin:0;}                  /* the row grid handles spacing */
.form .wpcf7-form > p:empty{display:none;margin:0;}
.form input.wpcf7-form-control,
.form select.wpcf7-form-control,
.form textarea.wpcf7-form-control{
  font-family:var(--sans);font-size:16px;color:var(--ink);width:100%;
  border:1px solid var(--line);background:#fafafa;border-radius:12px;
  padding:13px 15px;outline:none;transition:border-color .15s ease,background .15s ease;
}
.form input.wpcf7-form-control:focus,
.form select.wpcf7-form-control:focus,
.form textarea.wpcf7-form-control:focus{border-color:#bdbdbd;background:#fff;}
.form textarea.wpcf7-form-control{min-height:130px;resize:vertical;}
.form input[type=submit].wpcf7-submit{
  width:auto;border:0;cursor:pointer;background:var(--ink);color:#fff;
  font-weight:600;font-size:16px;padding:15px 28px;border-radius:999px;transition:opacity .15s ease;
}
.form input[type=submit].wpcf7-submit:hover{opacity:.88;}
.wpcf7 .wpcf7-response-output{border-radius:12px;margin:12px 0 0;padding:12px 16px;font-size:14px;}

/* pagination */
.pagination,.nav-links.pagination{display:flex;gap:8px;flex-wrap:wrap;padding:10px 0 70px;}
.pagination .page-numbers{
  border:1px solid var(--line);border-radius:10px;padding:9px 14px;font-size:14px;color:#333;background:#fafafa;
}
.pagination .page-numbers.current{background:var(--ink);color:#fff;border-color:var(--ink);}

/* generic page + posts */
.page-content .entry{max-width:72ch;font-size:17px;line-height:1.7;color:#333;padding-bottom:60px;}
.post-list{display:grid;gap:22px;padding-bottom:60px;}
.post-item h2{margin:0 0 6px;font-size:22px;}
.post-excerpt{color:#555;}
