/*
Theme Name: Ornate
Theme URI: https://www.ornatepiercingandtattoos.co.uk
Author: Burntwood Business
Description: Bespoke, lightweight theme for Ornate Piercings & Tattoos. Hand-built, no page builder, no parent theme. Body piercing, fine jewellery and tattoos in Burntwood, Staffordshire.
Version: 1.6.1
Requires at least: 6.5
Requires PHP: 8.0
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: ornate
*/

/* ---------- Brand palette (mirror ornate_brand() colours in functions.php) ---------- */
:root{
  --ink:#0d0d0f; --ink-soft:#17171b;
  --paper:#f5f1e8; --paper-2:#efe9dc;
  --cream:#dedcd0;
  --gold:#b08d57; --gold-bright:#c9a36a;
  --line:#e3dccc; --muted:#6b6760; --white:#fff;
  --display:"Cormorant Garamond",Georgia,serif;
  --body:"Inter",-apple-system,system-ui,sans-serif;
  --r:10px; --r-lg:18px;
  --ease:cubic-bezier(.2,.7,.2,1);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--body);color:var(--ink);background:var(--paper);line-height:1.6;-webkit-font-smoothing:antialiased}
h1,h2,h3{font-family:var(--display);font-weight:600;line-height:1.08;letter-spacing:.01em}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
.wrap{max-width:1140px;margin:0 auto;padding:0 24px}
.eyebrow{font-family:var(--body);font-size:12px;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:var(--gold)}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:9px;min-height:50px;padding:0 28px;border-radius:var(--r);font-family:var(--body);font-weight:600;font-size:15px;letter-spacing:.02em;cursor:pointer;border:1px solid transparent;transition:transform .25s var(--ease),background .25s,color .25s,box-shadow .25s}
.btn svg{width:18px;height:18px}
.btn-gold{background:var(--gold);color:#1a1407}.btn-gold:hover{background:var(--gold-bright);transform:translateY(-2px);box-shadow:0 10px 24px rgba(176,141,87,.32)}
.btn-ink{background:var(--ink);color:var(--paper)}.btn-ink:hover{transform:translateY(-2px);box-shadow:0 10px 24px rgba(13,13,15,.25)}
.btn-outline{background:transparent;border-color:rgba(255,255,255,.4);color:#fff}.btn-outline:hover{background:rgba(255,255,255,.1)}
.btn-ghost{background:transparent;border-color:var(--ink);color:var(--ink)}.btn-ghost:hover{background:var(--ink);color:var(--paper)}

/* ---------- Header / nav ---------- */
.site-header{position:sticky;top:0;z-index:50;background:rgba(13,13,15,.92);backdrop-filter:blur(10px);border-bottom:1px solid rgba(255,255,255,.08)}
.site-header .wrap{display:flex;align-items:center;justify-content:space-between;height:74px}
.site-logo a{font-family:var(--display);font-weight:700;font-size:30px;letter-spacing:.18em;color:#fff;text-transform:uppercase;line-height:1}
.site-logo img{max-height:40px;width:auto;display:block}
@media(max-width:480px){.site-logo img{max-height:32px}}
.nav-wrap{display:flex;align-items:center;gap:30px}
.primary-nav ul{list-style:none;display:flex;align-items:center;gap:28px;margin:0;padding:0}
.primary-nav a{color:#e7e4dd;font-size:14px;font-weight:500;letter-spacing:.04em;transition:color .2s}
.primary-nav a:hover{color:var(--gold-bright)}
.book-top{min-height:44px;padding:0 20px;font-size:14px}
.nav-toggle{display:none;background:none;border:0;color:#fff;cursor:pointer;padding:6px}
@media(max-width:880px){
  .nav-toggle{display:inline-flex}
  .primary-nav{position:absolute;top:74px;left:0;right:0;background:var(--ink);display:none;border-bottom:1px solid rgba(255,255,255,.1)}
  .primary-nav.open{display:block}
  .primary-nav ul{flex-direction:column;gap:0;padding:8px 24px}
  .primary-nav li{width:100%;border-bottom:1px solid rgba(255,255,255,.06)}
  .primary-nav a{display:block;padding:14px 0}
  .book-top{padding:0 16px}
}

/* ---------- Announcement bar ---------- */
.announce-bar{background:var(--gold);color:#1a1407;font-family:var(--body);font-size:13.5px;font-weight:600;letter-spacing:.03em}
.announce-bar .wrap{display:flex;align-items:center;justify-content:center;gap:10px;padding-top:11px;padding-bottom:11px;text-align:center}
.announce-bar svg{width:16px;height:16px;flex:none;opacity:.85}
.announce-bar a{color:#1a1407;text-decoration:underline;text-underline-offset:2px}
.announce-bar a:hover{opacity:.78}
@media(max-width:560px){.announce-bar{font-size:12.5px}.announce-bar .wrap{padding-top:9px;padding-bottom:9px}}

/* ---------- Hero ---------- */
.hero{position:relative;min-height:88vh;display:flex;align-items:center;color:#fff;overflow:hidden;background:var(--ink)}
.hero img.bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.5}
.hero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(13,13,15,.55),rgba(13,13,15,.35) 40%,rgba(13,13,15,.85))}
.hero .wrap{position:relative;z-index:2;padding:90px 24px}
.hero h1{font-size:clamp(40px,7vw,82px);max-width:14ch;font-weight:500}
.hero .lede{margin-top:22px;max-width:46ch;font-size:clamp(16px,2vw,19px);color:#e9e6df}
.hero .cta{margin-top:34px;display:flex;flex-wrap:wrap;gap:14px}
.hero .trust{margin-top:40px;display:flex;flex-wrap:wrap;gap:14px 30px;font-size:14px;color:#d8d4cb}
.hero .trust b{color:#fff}
.hero .trust a{display:inline-flex;gap:6px;align-items:center}
.hero .trust .star{color:var(--gold-bright)}

/* ---------- Trust strip ---------- */
.strip{background:var(--ink-soft);color:#cfcbc2}
.strip .wrap{display:flex;flex-wrap:wrap;justify-content:center;gap:14px 44px;padding:18px 24px;text-align:center;font-size:13.5px;letter-spacing:.04em}
.strip span{display:inline-flex;align-items:center;gap:9px}
.strip b{color:#fff;font-weight:600}.strip .g{color:var(--gold-bright)}

/* ---------- Sections ---------- */
section{padding:96px 0}
.center{text-align:center;max-width:680px;margin:0 auto 56px}
.center h2{font-size:clamp(30px,4.5vw,46px);margin:14px 0 0}
.center p{color:var(--muted);margin-top:14px;font-size:17px}

/* Welcome */
.welcome{background:var(--paper)}
.welcome .grid{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
.welcome .imgwrap{position:relative;border-radius:var(--r-lg);overflow:hidden;aspect-ratio:4/5;background:var(--ink)}
.welcome .imgwrap img{width:100%;height:100%;object-fit:cover}
.welcome h2{font-size:clamp(30px,4vw,44px)}
.welcome .sig{font-family:var(--display);font-style:italic;font-size:24px;color:var(--gold);margin-top:8px}
.welcome p{margin-top:18px;color:#3c3a35}
.badge-ukapp{display:inline-flex;align-items:center;gap:10px;margin-top:24px;padding:12px 18px;border:1px solid var(--line);border-radius:var(--r);background:var(--white);font-size:14px;transition:border-color .25s,box-shadow .25s}
.badge-ukapp:hover{border-color:var(--gold);box-shadow:0 6px 16px rgba(176,141,87,.18)}
.badge-ukapp b{color:var(--ink)}
@media(max-width:860px){.welcome .grid{grid-template-columns:1fr;gap:34px}}

/* Services */
.services{background:var(--ink);color:#fff}
.services .center h2{color:#fff}.services .center p{color:#b9b5ac}
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.svc{position:relative;border-radius:var(--r-lg);overflow:hidden;min-height:420px;display:flex;align-items:flex-end;background:#000}
.svc img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.62;transition:transform .6s var(--ease),opacity .4s}
.svc:hover img{transform:scale(1.06);opacity:.72}
.svc::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 35%,rgba(0,0,0,.82))}
.svc .body{position:relative;z-index:2;padding:28px}
.svc h3{font-size:30px;color:#fff}
.svc p{color:#ddd9d0;font-size:14.5px;margin:8px 0 16px}
.svc .more{font-size:13px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--gold-bright);display:inline-flex;align-items:center;gap:7px}
@media(max-width:860px){.cards{grid-template-columns:1fr}}

/* Team */
.team{background:var(--paper-2)}
.tgrid{display:flex;flex-wrap:wrap;justify-content:center;gap:34px 40px;max-width:980px;margin:0 auto}
.tgrid .member{flex:0 0 220px}
.member{text-align:center}
.member .ph{aspect-ratio:1;border-radius:50%;overflow:hidden;width:200px;margin:0 auto 18px;background:var(--ink);border:3px solid var(--white);box-shadow:0 8px 22px rgba(0,0,0,.1)}
.member .ph img{width:100%;height:100%;object-fit:cover}
.member h3{font-size:25px}
.member .role{color:var(--gold);font-size:13px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;margin-top:4px}
.member .link{margin-top:12px;display:inline-block;font-size:13px;font-weight:600;letter-spacing:.08em;color:var(--ink);border-bottom:1px solid var(--gold)}
@media(max-width:860px){.tgrid{grid-template-columns:1fr;max-width:380px}}

/* Jewellery band */
.jewel{position:relative;color:#fff;background:var(--ink);overflow:hidden}
.jewel img.bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.4}
.jewel::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(13,13,15,.85),rgba(13,13,15,.45))}
.jewel .wrap{position:relative;z-index:2;text-align:center;max-width:640px}
.jewel h2{font-size:clamp(32px,5vw,52px);color:#fff}
.jewel p{color:#e3e0d8;margin:16px auto 28px;max-width:48ch}

/* Reviews */
.reviews{background:var(--paper)}
.rgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:8px}
.rev{background:var(--white);border:1px solid var(--line);border-radius:var(--r-lg);padding:28px}
.rev .stars{color:var(--gold);letter-spacing:3px;font-size:15px}
.rev p{margin:14px 0 18px;font-size:15.5px;color:#3c3a35}
.rev .who{font-weight:600;font-size:14px}
.rev .who span{display:block;color:var(--muted);font-weight:400;font-size:13px}
.gscore{display:flex;align-items:center;justify-content:center;gap:14px;margin-top:42px;font-size:15px;color:var(--muted)}
.gscore b{font-family:var(--display);font-size:40px;color:var(--ink);line-height:1}
@media(max-width:860px){.rgrid{grid-template-columns:1fr}}

/* Booking CTA */
.bookcta{background:var(--ink);color:#fff;text-align:center}
.bookcta h2{font-size:clamp(32px,5vw,52px);color:#fff;max-width:18ch;margin:0 auto}
.bookcta p{color:#bdb9b0;margin:16px auto 30px;max-width:50ch}
.bookcta .cta{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* ---------- Generic page (policies) ---------- */
.page-hero{background:var(--ink);color:#fff;padding:72px 0 64px}
.page-hero h1{font-size:clamp(34px,5vw,56px)}
.page-hero .eyebrow{color:var(--gold-bright)}
.page-body{padding:64px 0}
.page-body .wrap{max-width:820px}
.page-body h2{font-family:var(--display);font-size:30px;margin:34px 0 12px}
.page-body h3{font-family:var(--display);font-size:23px;margin:26px 0 10px}
.page-body p,.page-body li{color:#3c3a35;font-size:16px;margin-bottom:14px}
.page-body ul,.page-body ol{margin:0 0 18px 22px}
.page-body a{color:var(--gold);border-bottom:1px solid var(--gold)}
.rule{width:56px;height:3px;background:var(--gold);border-radius:2px;margin:14px 0 4px}

/* ---------- Footer ---------- */
.site-footer{background:#08080a;color:#b7b3aa;padding:72px 0 32px}
.site-footer .fgrid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:44px}
.site-footer .logo{margin-bottom:16px}
.site-footer .logo img{height:38px;width:auto;display:block}
.site-footer h4{font-family:var(--body);font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);margin-bottom:16px}
.site-footer a{display:block;color:#cbc7be;font-size:14.5px;padding:5px 0;transition:color .2s}
.site-footer a:hover{color:#fff}
.site-footer .contact p{font-size:14.5px;color:#cbc7be;margin-bottom:10px}
.map{margin-top:14px;border-radius:var(--r);overflow:hidden;border:1px solid rgba(255,255,255,.1)}
.map iframe{width:100%;height:160px;border:0;display:block;filter:grayscale(.3)}
.map .map-ph{display:flex;flex-direction:column;gap:8px;align-items:flex-start;justify-content:center;height:160px;padding:16px;background:#15151a;font-size:13px;color:#9b978f}
.map .map-ph a{color:var(--gold-bright);border-bottom:1px solid var(--gold);display:inline}
.fbar{border-top:1px solid rgba(255,255,255,.08);margin-top:48px;padding-top:24px;display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;font-size:13px;color:#7f7c74}
.fbar a{display:inline;color:#9b978f}
.socials{display:flex;gap:14px}
.socials a{display:inline-flex;width:38px;height:38px;border:1px solid rgba(255,255,255,.18);border-radius:50%;align-items:center;justify-content:center;color:#cbc7be;padding:0}
.socials a:hover{background:var(--gold);color:#1a1407;border-color:var(--gold)}
.socials svg{width:17px;height:17px}
@media(max-width:760px){.site-footer .fgrid{grid-template-columns:1fr;gap:34px}}

/* ---------- Cookie banner ---------- */
.cookie-bar{position:fixed;left:16px;right:16px;bottom:16px;z-index:90;max-width:560px;margin:0 auto;background:var(--ink);color:#e7e4dd;border:1px solid rgba(176,141,87,.4);border-radius:var(--r-lg);box-shadow:0 16px 40px rgba(0,0,0,.4);padding:22px 24px;display:none}
.cookie-bar.show{display:block}
.cookie-bar h4{font-family:var(--display);color:#fff;font-size:22px;margin-bottom:6px}
.cookie-bar p{font-size:13.5px;color:#c8c4bb;margin-bottom:16px}
.cookie-bar p a{color:var(--gold-bright);border-bottom:1px solid var(--gold)}
.cookie-bar .row{display:flex;gap:10px;flex-wrap:wrap}
.cookie-bar .btn{min-height:42px;padding:0 20px;font-size:13.5px}
.cookie-bar .btn-min{background:transparent;border:1px solid rgba(255,255,255,.35);color:#e7e4dd}
.cookie-bar .btn-min:hover{background:rgba(255,255,255,.08)}

/* ---------- Shop (Fine Jewellery) ---------- */
.shop{padding:72px 0 96px;background:var(--paper)}
.shop-note{text-align:center;max-width:64ch;margin:0 auto 40px;color:var(--muted);font-size:15px}
.shop-note a{color:var(--gold);border-bottom:1px solid var(--gold)}
.shop-filters{display:flex;flex-wrap:wrap;justify-content:center;gap:10px;margin:0 0 36px}
.shop-filters .sf{font-family:var(--body);font-size:13px;font-weight:600;letter-spacing:.04em;padding:9px 18px;border:1px solid var(--line);background:var(--white);color:var(--muted);border-radius:999px;cursor:pointer;transition:background .2s var(--ease),color .2s,border-color .2s}
.shop-filters .sf:hover{border-color:var(--gold);color:var(--ink)}
.shop-filters .sf.is-active{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.shop-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.pcard{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;display:flex;flex-direction:column;transition:transform .25s var(--ease),box-shadow .25s}
.pcard:hover{transform:translateY(-4px);box-shadow:0 14px 30px rgba(13,13,15,.1)}
.pcard-img{aspect-ratio:1;background:#efe9dc;overflow:hidden}
.pcard-img img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.pcard:hover .pcard-img img{transform:scale(1.05)}
.pcard-body{padding:22px;display:flex;flex-direction:column;gap:7px;flex:1}
.pcard-brand{font-size:11px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--gold)}
.pcard-name{font-family:var(--display);font-size:22px;line-height:1.12;color:var(--ink)}
.pcard-desc{font-size:13px;color:var(--muted);line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.pcard-foot{margin-top:auto;padding-top:16px;display:flex;align-items:center;justify-content:space-between;gap:10px}
.pcard-price{font-family:var(--display);font-weight:600;font-size:26px;color:var(--ink)}
.pcard-buy{min-height:42px;padding:0 18px;font-size:13px}
.shop-help{max-width:680px;margin:64px auto 0;text-align:center}
.shop-help h2{font-size:30px;margin-bottom:10px}
.shop-help p{color:var(--muted);font-size:15.5px}
.shop-help a{color:var(--gold);border-bottom:1px solid var(--gold)}
@media(max-width:900px){.shop-grid{grid-template-columns:repeat(2,1fr);gap:18px}}
@media(max-width:560px){.shop-grid{grid-template-columns:1fr}}

/* ---------- Contact page ---------- */
.contact-page{padding:72px 0 96px;background:var(--paper)}
.contact-grid{display:grid;grid-template-columns:1.25fr .85fr;gap:56px;align-items:start}
.contact-form-wrap h2,.contact-info h2{font-size:28px;margin-bottom:18px}
.form-notice{padding:14px 18px;border-radius:var(--r);margin-bottom:22px;font-size:15px;border:1px solid}
.form-notice.is-ok{background:#eef5ec;border-color:#bcd8b4;color:#26551d}
.form-notice.is-err{background:#fbeeee;border-color:#e3bcbc;color:#7a2222}
.form-notice a{color:inherit;text-decoration:underline}
.ornate-form .field{display:block;margin-bottom:18px}
.ornate-form .field>span{display:block;font-family:var(--body);font-size:13px;font-weight:600;letter-spacing:.04em;color:var(--ink);margin-bottom:7px}
.ornate-form .field>span em{color:var(--gold);font-style:normal}
.ornate-form .field>span small{color:var(--muted);font-weight:500}
.ornate-form input,.ornate-form textarea{width:100%;font-family:var(--body);font-size:15px;color:var(--ink);background:var(--white);border:1px solid var(--line);border-radius:var(--r);padding:13px 15px;transition:border-color .2s var(--ease),box-shadow .2s}
.ornate-form input:focus,.ornate-form textarea:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(176,141,87,.16)}
.ornate-form textarea{resize:vertical;min-height:130px}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.ornate-form .btn-gold{margin-top:6px}
.form-fine{margin-top:16px;font-size:12.5px;color:var(--muted);max-width:52ch}
.form-fine a{color:var(--gold);border-bottom:1px solid var(--gold)}
.hp-field{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.contact-info{background:var(--white);border:1px solid var(--line);border-radius:var(--r-lg);padding:34px 32px}
.contact-info h3{font-size:14px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--gold);margin:26px 0 8px}
.contact-info .ci-addr strong{color:var(--ink)}
.contact-info p{font-size:15px;color:var(--muted);margin-bottom:4px}
.contact-info a{color:var(--ink)}
.contact-info .btn-ink{color:var(--paper)}
.contact-info .ci-line a{border-bottom:1px solid var(--gold)}
.contact-info .btn-ink{margin-top:6px}
.contact-info .ci-map{margin-top:24px}
.contact-info .ci-map a{color:var(--gold);border-bottom:1px solid var(--gold)}
@media(max-width:860px){.contact-grid{grid-template-columns:1fr;gap:36px}}
@media(max-width:480px){.field-row{grid-template-columns:1fr;gap:0}}

/* ---------- Reduced motion ---------- */
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto!important}
  .btn:hover,.svc:hover img{transform:none}
}
