/* Brush & Soul Studio — shared design system (v2: vibrant, jewel/earth, curved) */
:root{
  --parchment:#F7EEE0;
  --parchment-deep:#EFE2CE;
  --ink:#2A1B2E;            /* deep plum */
  --ink-soft:#5E4B5A;
  --lapis:#1C4C86;         /* sapphire */
  --lapis-deep:#143A68;
  --emerald:#1E7A5E;
  --pomegranate:#A6324A;   /* ruby */
  --saffron:#DCA13A;
  --saffron-deep:#C98A22;
  --terracotta:#C2683C;
  --amethyst:#6E4E8F;
  --turquoise:#2E9E94;
  --mat:#E9D7BD;           /* warm sand mat behind art */
  --art-ph:#EFE6D6;        /* placeholder art tint */
  --cats-bg:#F1E4D0;       /* funnel band */
  --line:rgba(42,27,46,0.14);
  --display:"Fraunces",Georgia,serif;
  --body:"Mulish",system-ui,sans-serif;
  --maxw:1180px;
  --flourish:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='66' height='16' viewBox='0 0 66 16'%3E%3Cpath d='M3 8 C15 8 19 3 27 8 C31 11 35 11 33 8' fill='none' stroke='%23A6324A' stroke-width='1.4' stroke-linecap='round'/%3E%3Cpath d='M63 8 C51 8 47 3 39 8 C35 11 31 11 33 8' fill='none' stroke='%23A6324A' stroke-width='1.4' stroke-linecap='round'/%3E%3Ccircle cx='33' cy='8' r='2.4' fill='%23DCA13A'/%3E%3C/svg%3E");
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--body);color:var(--ink);background:var(--parchment);line-height:1.65;-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 28px}
.eyebrow{font-family:var(--display);font-style:italic;font-weight:400;color:var(--pomegranate);font-size:1.18rem;letter-spacing:.01em}
h1,h2,h3{font-family:var(--display);font-weight:500;line-height:1.08;color:var(--ink)}
.btn{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--body);font-weight:600;font-size:.92rem;letter-spacing:.02em;padding:.85rem 1.7rem;border-radius:2rem;cursor:pointer;border:1.5px solid transparent;transition:transform .18s ease,background .18s ease,color .18s ease}
.btn-primary{background:var(--lapis);color:var(--parchment)}
.btn-primary:hover{background:var(--lapis-deep);transform:translateY(-2px)}
.btn-ghost{border-color:var(--ink);color:var(--ink)}
.btn-ghost:hover{background:var(--ink);color:var(--parchment);transform:translateY(-2px)}
.btn-saffron{background:var(--saffron);color:var(--ink)}
.btn-saffron:hover{background:var(--saffron-deep);transform:translateY(-2px)}
:focus-visible{outline:2.5px solid var(--saffron);outline-offset:3px;border-radius:4px}

/* arch = decorative niche FRAME; square art sits padded inside, never clipped */
.arch{
  border-radius:50% 50% 14px 14px / 44% 44% 0 0;
  background:var(--mat);
  border:1px solid var(--line);
  padding:20px 20px 20px;
  display:flex;align-items:flex-end;justify-content:center;
  overflow:hidden;position:relative;
}
.arch .ph{
  position:static;width:100%;aspect-ratio:1;
  border-radius:9px;background:var(--art-ph);
  border:1.5px solid rgba(42,27,46,.10);
  display:flex;align-items:center;justify-content:center;
  color:var(--ink-soft);font-style:italic;font-family:var(--display);font-size:.9rem;text-align:center;
}
.arch .ph span{background:rgba(255,255,255,.6);padding:.2rem .7rem;border-radius:1rem}
/* fill variant — for hero/portrait images that suit a full-bleed arch */
.arch.fill{padding:0;align-items:stretch}
.arch.fill .ph{aspect-ratio:auto;width:100%;height:100%;border:none;border-radius:0}

/* header */
header{position:sticky;top:0;z-index:50;background:rgba(247,238,224,.9);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:74px}
.brand{font-family:var(--display);font-weight:600;font-size:1.4rem;letter-spacing:.01em}
.brand small{display:block;font-family:var(--body);font-weight:600;font-size:.6rem;letter-spacing:.32em;text-transform:uppercase;color:var(--terracotta);margin-top:-2px}
.menu{display:flex;align-items:center;gap:1.9rem;list-style:none}
.menu a{font-weight:600;font-size:.86rem;letter-spacing:.02em;padding:.3rem 0;position:relative}
.menu a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:1.5px;background:var(--pomegranate);transition:width .22s ease}
.menu a:hover::after,.menu a.active::after{width:100%}
.navbtns{display:flex;align-items:center;gap:1rem}
.icon-cart{font-size:1.2rem}
.burger{display:none;background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--ink)}

/* hero */
.hero{padding:62px 0 78px}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center}
.hero h1{font-size:clamp(2.6rem,5.2vw,4.4rem);margin:.7rem 0 1.1rem}
.hero p.lead{font-size:1.2rem;color:var(--ink-soft);max-width:30ch;margin-bottom:1.9rem}
.hero-cta{display:flex;gap:.9rem;flex-wrap:wrap}
.hero-art{height:540px}

/* interior page hero */
.page-hero{padding:64px 0 26px;text-align:center}
.page-hero h1{font-size:clamp(2.3rem,4.6vw,3.7rem);margin:.5rem 0 .4rem}
.page-hero h1::after{content:"";display:block;width:66px;height:16px;margin:16px auto 0;background:var(--flourish) center/contain no-repeat}
.page-hero p{color:var(--ink-soft);font-size:1.14rem;max-width:46ch;margin:0 auto}

/* sections */
section{padding:74px 0}
.sec-head{text-align:center;max-width:640px;margin:0 auto 48px}
.sec-head h2{font-size:clamp(1.9rem,3.6vw,2.8rem);margin:.4rem 0 0}
.sec-head h2::after{content:"";display:block;width:66px;height:16px;margin:16px auto 0;background:var(--flourish) center/contain no-repeat}
.sec-head p{color:var(--ink-soft);margin-top:.8rem}

/* category funnel — scalloped top edge for curvature */
.cats{background:var(--cats-bg);position:relative}
.cats::before{content:"";position:absolute;top:-21px;left:0;right:0;height:22px;background-image:radial-gradient(circle at 22px 22px,var(--cats-bg) 21px,transparent 22px);background-size:44px 22px;background-repeat:repeat-x}
.cat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px}
.cat{display:block;text-align:center;transition:transform .2s ease}
.cat:hover{transform:translateY(-6px)}
.cat .arch{height:360px;margin-bottom:18px}
.cat h3{font-size:1.5rem;margin-bottom:.25rem}
.cat .dot{display:inline-block;width:9px;height:9px;border-radius:50%;margin-right:7px;vertical-align:middle}
.cat p{color:var(--ink-soft);font-size:.95rem}

/* featured cards */
.feat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.card .arch{height:320px;margin-bottom:14px}
.card h4{font-family:var(--display);font-weight:500;font-size:1.14rem}
.card .price{font-weight:700;color:var(--lapis);font-size:.95rem;margin-top:.15rem}
.card .tag{font-size:.72rem;letter-spacing:.04em;text-transform:uppercase;color:var(--pomegranate);font-weight:700}

/* commissions (deep plum band) */
.comm{background:var(--ink);color:var(--parchment)}
.comm h2,.comm h3{color:var(--parchment)}
.comm .eyebrow{color:var(--saffron)}
.comm .sec-head p{color:rgba(247,238,224,.72)}
.comm .sec-head h2::after{filter:none}
.comm-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:54px;align-items:start}
.steps{list-style:none;display:grid;gap:1.1rem}
.steps li{display:flex;gap:1rem;align-items:flex-start}
.steps .n{font-family:var(--display);font-size:1.5rem;color:var(--saffron);line-height:1;min-width:1.6rem}
.steps strong{display:block;font-weight:700;margin-bottom:.1rem}
.steps span{color:rgba(247,238,224,.7);font-size:.92rem}
.ptable{width:100%;border-collapse:collapse;margin:.4rem 0 1.6rem;font-size:.95rem}
.ptable th,.ptable td{text-align:left;padding:.85rem .6rem;border-bottom:1px solid rgba(247,238,224,.16)}
.ptable th{font-weight:700;font-size:.74rem;letter-spacing:.06em;text-transform:uppercase;color:rgba(247,238,224,.6)}
.ptable .dim{font-weight:600}
.ptable .aka{color:rgba(247,238,224,.5);font-size:.84rem}
.ptable .amt{font-family:var(--display);font-weight:600;color:var(--saffron);font-size:1.1rem;text-align:right}
.comm small.note{color:rgba(247,238,224,.6);font-size:.85rem}
.ptable-light th,.ptable-light td{border-bottom:1px solid var(--line)}
.ptable-light th{color:var(--ink-soft)}
.ptable-light .aka{color:var(--ink-soft)}
.ptable-light .amt{color:var(--lapis)}

/* estimator */
.estimator{background:var(--parchment-deep);border:1px solid var(--line);border-radius:22px;padding:32px}
.estimator h3{font-size:1.4rem;margin-bottom:.3rem}
.estimator .sub{color:var(--ink-soft);font-size:.92rem;margin-bottom:1.3rem}
.field{margin-bottom:1.2rem}
.field > label{display:block;font-weight:700;font-size:.82rem;letter-spacing:.02em;margin-bottom:.5rem}
.seg{display:flex;flex-wrap:wrap;gap:.5rem}
.seg button{font-family:var(--body);font-weight:600;font-size:.85rem;padding:.55rem .9rem;border:1.5px solid var(--line);background:#fff;color:var(--ink);border-radius:1.5rem;cursor:pointer;transition:all .15s ease}
.seg button[aria-pressed="true"]{background:var(--lapis);color:var(--parchment);border-color:var(--lapis)}
.est-out{margin-top:1.4rem;background:#fff;border:1px solid var(--line);border-radius:16px;padding:20px 22px}
.est-out .row{display:flex;justify-content:space-between;align-items:baseline;gap:1rem}
.est-out .lab{color:var(--ink-soft);font-size:.9rem}
.est-out .big{font-family:var(--display);font-weight:600;font-size:2rem;color:var(--lapis)}
.est-out .range{font-family:var(--display);font-weight:500;font-size:1.05rem;color:var(--pomegranate)}
.est-out .exp{margin-top:.7rem;color:var(--ink-soft);font-size:.86rem;line-height:1.5}

/* forms */
.form{max-width:680px;margin:0 auto}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem}
.form .field label{font-weight:700;font-size:.82rem}
.form input,.form select,.form textarea{width:100%;padding:.8rem 1rem;border:1.5px solid var(--line);border-radius:12px;font-family:var(--body);font-size:.95rem;background:#fff;color:var(--ink)}
.form textarea{min-height:130px;resize:vertical}
.form .full{grid-column:1 / -1}
.form .help{font-size:.8rem;color:var(--ink-soft);margin-top:.3rem}

/* collections — jewel/earth tiles */
.coll-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.coll{height:180px;border-radius:18px;display:flex;align-items:flex-end;padding:18px;color:#fff;font-family:var(--display);font-weight:600;font-size:1.3rem;border:1px solid var(--line);transition:transform .2s ease}
.coll:hover{transform:translateY(-5px)}
.c-persian{background:var(--lapis)}
.c-mystical{background:var(--amethyst)}
.c-tarot{background:var(--pomegranate)}
.c-floral{background:var(--emerald)}

/* split panels */
.split{display:grid;grid-template-columns:1fr 1fr;gap:40px}
.panel{background:var(--parchment-deep);border:1px solid var(--line);border-radius:22px;padding:40px}
.panel .eyebrow{font-size:1rem}
.panel h3{font-size:1.7rem;margin:.3rem 0 .8rem}
.panel p{color:var(--ink-soft);margin-bottom:1.3rem}
.about-quote{font-family:var(--display);font-style:italic;font-size:1.15rem;color:var(--ink);border-left:2px solid var(--saffron);padding-left:1rem;margin-bottom:1.3rem}

/* about prose */
.prose{max-width:680px;margin:0 auto;font-size:1.14rem;color:var(--ink-soft)}
.prose p{margin-bottom:1.3rem}
.prose .pull{font-family:var(--display);font-style:italic;font-size:1.5rem;color:var(--ink);line-height:1.3;margin:2rem 0;text-align:center}
.about-grid{display:grid;grid-template-columns:.8fr 1.2fr;gap:48px;align-items:center}
.about-grid .arch{height:480px}

/* faq */
.faq{max-width:760px;margin:0 auto}
.faq details{border-bottom:1px solid var(--line);padding:1.1rem 0}
.faq summary{font-family:var(--display);font-weight:500;font-size:1.2rem;cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";color:var(--pomegranate);font-size:1.4rem;font-family:var(--body)}
.faq details[open] summary::after{content:"\2013"}
.faq p{color:var(--ink-soft);padding-top:.7rem}

/* newsletter + footer */
.news{background:var(--lapis);color:var(--parchment);text-align:center}
.news h2{color:var(--parchment);font-size:clamp(1.8rem,3.4vw,2.5rem);margin-bottom:.6rem}
.news h2::after{content:"";display:block;width:66px;height:16px;margin:14px auto 0;background:var(--flourish) center/contain no-repeat}
.news p{color:rgba(247,238,224,.85);max-width:42ch;margin:0 auto 1.6rem}
.news form{display:flex;gap:.7rem;max-width:440px;margin:0 auto;flex-wrap:wrap;justify-content:center}
.news input{flex:1;min-width:200px;padding:.85rem 1.1rem;border-radius:2rem;border:none;font-family:var(--body);font-size:.95rem}
.news .btn-primary{background:var(--saffron);color:var(--ink)}
.news .btn-primary:hover{background:var(--saffron-deep)}
footer{background:var(--ink);color:rgba(247,238,224,.72);padding:48px 0 34px;font-size:.9rem}
.foot-grid{display:flex;justify-content:space-between;gap:30px;flex-wrap:wrap;margin-bottom:26px}
footer a:hover{color:var(--saffron)}
footer .brand{color:var(--parchment)}
.foot-col h5{color:var(--parchment);font-family:var(--body);font-size:.78rem;letter-spacing:.08em;text-transform:uppercase;margin-bottom:.8rem}
.foot-col a{display:block;margin-bottom:.45rem}
.foot-bottom{border-top:1px solid rgba(247,238,224,.14);padding-top:20px;font-size:.82rem;color:rgba(247,238,224,.5)}

.reveal{opacity:0;transform:translateY(18px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}

@media(max-width:900px){
  .hero-grid{grid-template-columns:1fr;gap:34px}
  .hero-art{height:400px;order:-1}
  .comm-grid{grid-template-columns:1fr;gap:34px}
  .feat-grid{grid-template-columns:repeat(2,1fr)}
  .coll-grid{grid-template-columns:repeat(2,1fr)}
  .split,.about-grid,.form-grid{grid-template-columns:1fr}
  .about-grid .arch{height:360px;order:-1}
  .menu{display:none}
  .burger{display:block}
}
@media(max-width:560px){
  .cat-grid{grid-template-columns:1fr;gap:22px}
  .feat-grid{grid-template-columns:1fr 1fr}
}
@media(prefers-reduced-motion:reduce){
  *{scroll-behavior:auto}
  .reveal{opacity:1;transform:none;transition:none}
  .btn,.cat,.coll{transition:none}
}

/* shop / catalog */
.shop-bar{background:var(--parchment-deep);border:1px solid var(--line);border-radius:18px;padding:20px 22px;margin-bottom:32px;display:grid;gap:16px}
.filter-group{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.filter-group > .lbl{font-weight:700;font-size:.74rem;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-soft);margin-right:4px}
.chip{font-family:var(--body);font-weight:600;font-size:.84rem;padding:.45rem .9rem;border:1.5px solid var(--line);background:#fff;color:var(--ink);border-radius:1.5rem;cursor:pointer;transition:all .15s ease}
.chip[aria-pressed="true"]{background:var(--lapis);color:var(--parchment);border-color:var(--lapis)}
.shop-controls{display:flex;flex-wrap:wrap;gap:16px 28px;align-items:center;justify-content:space-between;border-top:1px solid var(--line);padding-top:16px}
.price-control{display:flex;align-items:center;gap:10px;min-width:260px;flex:1}
.price-control input[type=range]{flex:1}
.price-control .val{font-weight:700;font-size:.88rem;min-width:78px;text-align:right;color:var(--lapis)}
.results-meta{color:var(--ink-soft);font-size:.9rem}
.shop-sort{padding:.5rem .8rem;border:1.5px solid var(--line);border-radius:10px;background:#fff;font-family:var(--body);font-size:.88rem;color:var(--ink)}
.shop-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.shop-empty{grid-column:1/-1;text-align:center;color:var(--ink-soft);padding:50px 0;font-family:var(--display);font-style:italic;font-size:1.2rem}
.type-group{display:none}
.type-group.show{display:flex}
@media(max-width:900px){.shop-grid{grid-template-columns:repeat(2,1fr)}}

/* real imagery */
.brand{display:flex;align-items:center;gap:11px}
.brand-mark{height:40px;width:auto;border-radius:8px;display:block}
.brand-txt{display:flex;flex-direction:column;line-height:1.05}
.arch img{display:block}
.arch .art-img{width:100%;aspect-ratio:1;object-fit:cover;border-radius:9px;border:1.5px solid rgba(42,27,46,.10)}
.arch.fill .art-img{aspect-ratio:auto;width:100%;height:100%;object-fit:cover;border:none;border-radius:0}

/* events */
.events-list{max-width:820px;margin:0 auto;display:grid;gap:18px}
.event{display:flex;gap:22px;align-items:flex-start;background:var(--parchment-deep);border:1px solid var(--line);border-radius:18px;padding:24px 26px}
.event-date{flex-shrink:0;width:80px;text-align:center;background:var(--lapis);color:var(--parchment);border-radius:14px;padding:12px 0}
.event-date .m{font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;font-weight:700}
.event-date .d{font-family:var(--display);font-size:1.85rem;line-height:1;margin-top:2px}
.event-body h3{font-size:1.35rem;margin-bottom:.2rem}
.event-meta{color:var(--pomegranate);font-weight:600;font-size:.88rem;margin-bottom:.5rem}
.event-body p{color:var(--ink-soft);font-size:.96rem}
.events-note{text-align:center;font-family:var(--display);font-style:italic;color:var(--ink-soft);margin-bottom:28px}
/* contact */
.contact-grid{display:grid;grid-template-columns:1.3fr .7fr;gap:48px;align-items:start;max-width:980px;margin:0 auto}
.contact-aside{background:var(--parchment-deep);border:1px solid var(--line);border-radius:18px;padding:30px}
.contact-aside h3{font-size:1.2rem;margin:0 0 .3rem}
.contact-aside .row{margin-bottom:1.1rem}
.contact-aside .lbl{font-weight:700;font-size:.74rem;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-soft);display:block;margin-bottom:.2rem}
.contact-aside a{color:var(--lapis);font-weight:600}
@media(max-width:760px){.contact-grid{grid-template-columns:1fr}}
