/*
Theme Name: Cape Town 3D
Theme URI: https://capetown3d.co.za
Author: Built for Hennie Pelser
Description: Custom dark, bold theme for Cape Town 3D — a hobby gallery of 3D-printed collectibles. Catalog/gallery style with contact-to-buy. Works with WooCommerce.
Version: 1.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 7.4
Text Domain: capetown3d
*/

@import url('https://fonts.googleapis.com/css2?family=Sora:wght@500;600;700;800&family=Inter:wght@400;500;600&display=swap');

:root{
  --bg:#0a0d12;
  --bg2:#0d1117;
  --panel:#121821;
  --panel2:#161d28;
  --line:#222c39;
  --text:#e8eef5;
  --muted:#94a3b8;
  --orange:#f97316;
  --orange2:#fb923c;
  --teal:#2dd4bf;
  --radius:16px;
}

*{box-sizing:border-box;}
html,body{margin:0;padding:0;}
body{
  background:var(--bg);
  color:var(--text);
  font-family:'Inter',Arial,sans-serif;
  font-size:18px;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
}
a{color:inherit;text-decoration:none;}
img{max-width:100%;height:auto;display:block;}
h1,h2,h3,h4{font-family:'Sora',Arial,sans-serif;line-height:1.1;margin:0 0 .4em;}

.c3d-wrap{max-width:1180px;margin:0 auto;padding:0 24px;}

/* ===== Header ===== */
.c3d-header{
  position:sticky;top:0;z-index:50;
  background:rgba(10,13,18,.82);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
}
.c3d-headinner{display:flex;align-items:center;justify-content:space-between;height:74px;}
.c3d-logo{display:flex;align-items:center;gap:10px;font-family:'Sora';font-weight:800;font-size:22px;letter-spacing:.3px;}
.c3d-badge{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:10px;background:linear-gradient(135deg,var(--orange),#ea580c);color:#fff;font-size:15px;font-weight:800;}
.c3d-accent{color:var(--orange);}
.c3d-nav{display:flex;gap:30px;}
.c3d-nav a{color:var(--muted);font-weight:500;font-size:16px;transition:color .2s;}
.c3d-nav a:hover{color:var(--text);}

/* ===== Buttons ===== */
.c3d-btn{display:inline-flex;align-items:center;gap:8px;padding:14px 26px;border-radius:12px;font-family:'Sora';font-weight:700;font-size:16px;cursor:pointer;transition:transform .15s,box-shadow .2s,background .2s;border:none;}
.c3d-btn-primary{background:linear-gradient(135deg,var(--orange),#ea580c);color:#fff;box-shadow:0 8px 24px rgba(249,115,22,.25);}
.c3d-btn-primary:hover{transform:translateY(-2px);box-shadow:0 12px 30px rgba(249,115,22,.35);}
.c3d-btn-ghost{background:transparent;color:var(--text);border:1px solid var(--line);}
.c3d-btn-ghost:hover{border-color:var(--orange);color:var(--orange);}
.c3d-btn-sm{padding:10px 18px;font-size:15px;background:transparent;border:1px solid var(--line);color:var(--text);}
.c3d-btn-sm:hover{border-color:var(--orange);color:var(--orange);}

/* ===== Hero ===== */
.c3d-hero{
  position:relative;overflow:hidden;
  background:radial-gradient(1100px 600px at 75% -10%,rgba(249,115,22,.13),transparent 60%),radial-gradient(900px 500px at 10% 110%,rgba(45,212,191,.08),transparent 55%),var(--bg);
  border-bottom:1px solid var(--line);
}
.c3d-hero-inner{max-width:1180px;margin:0 auto;padding:90px 24px 100px;}
.c3d-pill{display:inline-flex;align-items:center;gap:9px;padding:7px 16px;border:1px solid var(--line);border-radius:999px;background:var(--panel);font-size:13px;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted);font-weight:600;}
.c3d-dot{width:8px;height:8px;border-radius:50%;background:var(--orange);box-shadow:0 0 0 4px rgba(249,115,22,.2);}
.c3d-hero h1{font-size:clamp(40px,6vw,76px);font-weight:800;margin:26px 0 0;letter-spacing:-1px;}
.c3d-hero h1 .o{color:var(--orange);}
.c3d-hero h1 .t{color:var(--teal);}
.c3d-lead{max-width:620px;color:var(--muted);font-size:20px;margin:24px 0 34px;}
.c3d-cta{display:flex;gap:14px;flex-wrap:wrap;}
.c3d-ticks{display:flex;gap:26px;flex-wrap:wrap;margin-top:36px;color:var(--muted);font-size:15px;font-weight:500;}
.c3d-ticks span{display:inline-flex;align-items:center;gap:8px;}
.c3d-ticks .ck{color:var(--teal);font-weight:800;}

/* ===== Sections ===== */
.c3d-section{padding:80px 0;}
.c3d-section-head{text-align:center;max-width:680px;margin:0 auto 50px;}
.c3d-section-head h2{font-size:clamp(30px,4vw,46px);font-weight:800;}
.c3d-section-head p{color:var(--muted);font-size:19px;margin:10px 0 0;}
.c3d-eyebrow{color:var(--orange);font-weight:700;letter-spacing:2px;text-transform:uppercase;font-size:13px;font-family:'Sora';}

/* ===== Product grid (front page + shop) ===== */
.c3d-grid,.woocommerce ul.products{
  display:grid !important;grid-template-columns:repeat(3,1fr);gap:26px;margin:0;padding:0;list-style:none;
}
@media(max-width:900px){.c3d-grid,.woocommerce ul.products{grid-template-columns:repeat(2,1fr);}}
@media(max-width:560px){.c3d-grid,.woocommerce ul.products{grid-template-columns:1fr;}}

.c3d-card,.woocommerce ul.products li.product{
  background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;
  display:flex;flex-direction:column;transition:transform .18s,border-color .2s,box-shadow .2s;width:auto !important;margin:0 !important;float:none !important;
}
.c3d-card:hover,.woocommerce ul.products li.product:hover{transform:translateY(-4px);border-color:rgba(249,115,22,.5);box-shadow:0 16px 40px rgba(0,0,0,.4);}
.c3d-thumb{aspect-ratio:4/3;background:var(--panel2);overflow:hidden;}
.c3d-thumb img{width:100%;height:100%;object-fit:cover;}
.c3d-noimg{display:flex;align-items:center;justify-content:center;height:100%;color:#56627a;font-size:14px;letter-spacing:1px;}
.c3d-cardbody{padding:18px 20px 22px;display:flex;flex-direction:column;gap:8px;}
.c3d-cardbody h3{font-size:20px;font-weight:700;margin:0;}
.c3d-price,.woocommerce ul.products li.product .price{color:var(--orange) !important;font-weight:800 !important;font-size:20px !important;font-family:'Sora';}
.c3d-enquire{margin-top:6px;color:var(--teal);font-weight:600;font-size:15px;}
.c3d-empty{text-align:center;color:var(--muted);font-size:19px;padding:40px 0;}

/* WooCommerce product card text */
.woocommerce ul.products li.product a{padding:0;}
.woocommerce ul.products li.product img{margin:0 0 0;border-radius:0;}
.woocommerce ul.products li.product .woocommerce-loop-product__title{padding:16px 20px 4px !important;font-family:'Sora';font-weight:700;font-size:19px;color:var(--text) !important;}
.woocommerce ul.products li.product .price{display:block;padding:0 20px 18px;}
.woocommerce ul.products li.product .button{display:none !important;} /* catalog mode */

/* ===== Contact ===== */
.c3d-contact{background:linear-gradient(180deg,var(--bg),var(--bg2));border-top:1px solid var(--line);}
.c3d-contact-card{max-width:760px;margin:0 auto;text-align:center;background:var(--panel);border:1px solid var(--line);border-radius:22px;padding:50px 36px;}
.c3d-contact-card h2{font-size:clamp(28px,4vw,40px);font-weight:800;}
.c3d-contact-card p{color:var(--muted);font-size:19px;margin:10px auto 28px;max-width:540px;}
.c3d-contact-btns{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;}

/* ===== WooCommerce single + shop pages ===== */
.c3d-shop{padding:60px 0 90px;}
.woocommerce .woocommerce-breadcrumb{color:var(--muted);margin-bottom:24px;}
.woocommerce-products-header__title,.woocommerce div.product .product_title{font-family:'Sora';color:var(--text);}
.woocommerce div.product p.price,.woocommerce div.product span.price{color:var(--orange);font-weight:800;}
.woocommerce div.product .woocommerce-tabs ul.tabs li{background:var(--panel);border-color:var(--line);}
.woocommerce #respond input#submit,.woocommerce a.button,.woocommerce button.button{background:var(--orange);color:#fff;border-radius:10px;}
.woocommerce .woocommerce-result-count,.woocommerce .woocommerce-ordering{color:var(--muted);}
.woocommerce-message,.woocommerce-info{background:var(--panel);border-top-color:var(--orange);color:var(--text);}

/* ===== Footer ===== */
.c3d-footer{background:var(--bg2);border-top:1px solid var(--line);padding:50px 0 30px;color:var(--muted);}
.c3d-foot-inner{display:flex;justify-content:space-between;gap:30px;flex-wrap:wrap;}
.c3d-footer a:hover{color:var(--orange);}
.c3d-foot-brand{font-family:'Sora';font-weight:800;font-size:20px;color:var(--text);}
.c3d-foot-contact div{margin:4px 0;}
.c3d-copy{margin-top:34px;padding-top:20px;border-top:1px solid var(--line);font-size:14px;text-align:center;}
