/* ====== Catalina Ceramics — earthy artisan theme ====== */
:root{
  --cream:#f6f0e6; --cream-2:#efe7d8; --paper:#fbf7ef;
  --clay:#b07d56; --clay-deep:#9a6c48; --terra:#b5402f;
  --sage:#7d9482; --sage-deep:#5f7565;
  --ink:#3a342c; --ink-soft:#6b6155; --line:#e3d9c7;
  --charcoal:#2a251f;
  --shadow:0 24px 60px -28px rgba(58,52,44,.45);
  --radius:18px;
  --serif:"Fraunces",Georgia,serif; --sans:"Nunito Sans",system-ui,sans-serif;
  --hand:"Caveat",cursive;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--sans);color:var(--ink);background:var(--cream);
  line-height:1.65;-webkit-font-smoothing:antialiased;overflow-x:clip;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
em{font-style:italic}
h1,h2,h3{font-family:var(--serif);font-weight:400;line-height:1.04;letter-spacing:-.01em}
section{position:relative}

.eyebrow{font-size:.74rem;letter-spacing:.32em;text-transform:uppercase;
  color:var(--clay-deep);font-weight:700;margin-bottom:1rem}
.eyebrow.light{color:#e8d9bf}
.section-head{max-width:680px;margin:0 auto 3rem;text-align:center;padding:0 1.5rem}
.section-head h2{font-size:clamp(2.1rem,5vw,3.4rem)}
.section-lead{margin-top:1.1rem;color:var(--ink-soft);font-size:1.06rem}
.section-lead.light{color:#d9cdb8}
.section-lead a{color:var(--clay-deep);border-bottom:1px solid var(--clay)}
.light{color:var(--cream)}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:.5rem;font-weight:700;font-size:.95rem;
  padding:.92rem 1.7rem;border-radius:100px;cursor:pointer;border:1.5px solid transparent;
  transition:transform .25s,box-shadow .25s,background .25s,color .25s;white-space:nowrap}
.btn-solid{background:var(--ink);color:var(--cream)}
.btn-solid:hover{transform:translateY(-2px);box-shadow:0 14px 30px -12px rgba(42,37,31,.6)}
.btn-ghost{background:transparent;border-color:var(--ink);color:var(--ink)}
.btn-ghost:hover{background:var(--ink);color:var(--cream)}
.btn.full{width:100%;justify-content:center}

/* ====== NAV ====== */
.nav{position:fixed;top:0;left:0;right:0;z-index:50;transition:background .35s,box-shadow .35s,padding .35s;padding:1.15rem 0}
.nav.scrolled{background:rgba(246,240,230,.92);backdrop-filter:blur(12px);box-shadow:0 1px 0 var(--line);padding:.7rem 0}
.nav-inner{max-width:1240px;margin:0 auto;padding:0 1.6rem;display:flex;align-items:center;justify-content:space-between}
.brand{display:flex;align-items:center;gap:.6rem}
.brand-mark{font-family:var(--serif);font-style:italic;font-weight:500;background:var(--ink);color:var(--cream);
  width:38px;height:38px;border-radius:50%;display:grid;place-items:center;font-size:1.05rem;letter-spacing:-.04em}
.brand-name{font-family:var(--serif);font-size:1.18rem;letter-spacing:.01em}
.brand-name em{color:var(--clay-deep)}
.nav-links{display:flex;align-items:center;gap:2rem}
.nav-links a{font-weight:600;font-size:.96rem;position:relative}
.nav-links a:not(.nav-cta)::after{content:"";position:absolute;left:0;bottom:-5px;width:0;height:1.5px;background:var(--clay);transition:width .3s}
.nav-links a:not(.nav-cta):hover::after{width:100%}
.nav-cta{background:var(--ink);color:var(--cream);padding:.55rem 1.25rem;border-radius:100px}
.nav-cta:hover{background:var(--clay-deep)}
.nav-burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:6px}
.nav-burger span{width:24px;height:2px;background:var(--ink);transition:.3s}

/* ====== HERO ====== */
.hero{min-height:100vh;display:grid;grid-template-columns:1.05fr .95fr;align-items:center;gap:3rem;
  max-width:1240px;margin:0 auto;padding:8rem 1.6rem 4rem}
.hero-grain{position:absolute;inset:0;z-index:-1;background:
  radial-gradient(1200px 600px at 80% -5%,rgba(176,125,86,.16),transparent 60%),
  radial-gradient(900px 500px at -10% 110%,rgba(125,148,130,.18),transparent 60%)}
.hero h1{font-size:clamp(2.9rem,7vw,5.2rem);margin:.4rem 0 1.4rem}
.hero h1 em{color:var(--clay-deep)}
.hero-sub{font-size:1.14rem;color:var(--ink-soft);max-width:30rem;margin-bottom:2rem}
.hero-btns{display:flex;gap:1rem;flex-wrap:wrap}
.hero-img{position:relative;border-radius:26px;overflow:hidden;box-shadow:var(--shadow);
  transform:rotate(1.4deg)}
.hero-img img{width:100%;height:100%;object-fit:cover;aspect-ratio:4/4.4}
.hero-tag{position:absolute;left:18px;bottom:18px;background:rgba(251,247,239,.9);backdrop-filter:blur(6px);
  font-family:var(--hand);font-size:1.45rem;color:var(--terra);padding:.2rem 1rem;border-radius:100px;transform:rotate(-2deg)}

/* ====== MARQUEE ====== */
.marquee{background:var(--ink);color:var(--cream);overflow:hidden;padding:1rem 0}
.marquee-track{display:flex;gap:2.5rem;white-space:nowrap;width:max-content;animation:slide 28s linear infinite;font-family:var(--serif);font-size:1.15rem;font-style:italic}
.marquee-track span{opacity:.92}
@keyframes slide{to{transform:translateX(-50%)}}

/* ====== SHOP ====== */
.shop{padding:6rem 1.6rem;max-width:1240px;margin:0 auto}
.filters{display:flex;gap:.65rem;justify-content:center;flex-wrap:wrap;margin-bottom:3rem}
.chip{font-family:var(--sans);font-weight:700;font-size:.9rem;padding:.55rem 1.3rem;border-radius:100px;
  border:1.5px solid var(--line);background:var(--paper);color:var(--ink-soft);cursor:pointer;transition:.25s}
.chip:hover{border-color:var(--clay)}
.chip.is-active{background:var(--ink);color:var(--cream);border-color:var(--ink)}
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem}
.card{background:var(--paper);border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);
  transition:transform .35s,box-shadow .35s;opacity:0;transform:translateY(18px)}
.card.in{opacity:1;transform:none}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.card-img{position:relative;aspect-ratio:1/1;overflow:hidden}
.card-img img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
.card:hover .card-img img{transform:scale(1.06)}
.card-badge{position:absolute;top:12px;left:12px;background:rgba(251,247,239,.92);color:var(--clay-deep);
  font-size:.7rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:.3rem .7rem;border-radius:100px}
.card-tag{position:absolute;bottom:12px;right:12px;font-family:var(--hand);font-size:1.3rem;color:var(--terra);
  background:rgba(251,247,239,.92);padding:.05rem .8rem;border-radius:100px}
.card-body{padding:1.3rem 1.4rem 1.5rem}
.card-body h3{font-size:1.32rem}
.card-cat{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--sage-deep);font-weight:700}
.card-desc{font-size:.92rem;color:var(--ink-soft);margin:.5rem 0 1rem;min-height:2.6em}
.card-foot{display:flex;align-items:center;justify-content:space-between}
.card-price{font-family:var(--serif);font-size:1.3rem}
.card-btn{font-weight:700;font-size:.86rem;color:var(--clay-deep);border-bottom:1.5px solid var(--clay);padding-bottom:2px}
.card-btn:hover{color:var(--ink);border-color:var(--ink)}

/* ====== STUDIO ====== */
.studio{background:var(--charcoal);color:var(--cream);padding:6.5rem 1.6rem;overflow:hidden}
.studio-grain{position:absolute;inset:0;background:
  radial-gradient(800px 400px at 15% 0,rgba(176,125,86,.22),transparent 60%),
  radial-gradient(700px 500px at 100% 100%,rgba(125,148,130,.18),transparent 60%);pointer-events:none}
.studio-wrap{position:relative;max-width:1080px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:3.5rem;align-items:center}
.mug-stage{position:relative;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);background:#1f1b16}
.mug-stage img{width:100%;aspect-ratio:1/1;object-fit:cover}
.engrave-layer{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;
  pointer-events:none;padding-top:6%}
/* hand-painted marker lettering, like Catalina's real "wanna coffee?" hand.
   Gochi Hand is a printed-marker face (closer to her writing than a cursive);
   a light multiply sits the ink on the glaze without the watermark/blur look. */
.engrave-text{font-family:"Gochi Hand","Caveat",cursive;font-size:clamp(1.7rem,5.5vw,2.7rem);
  line-height:1.05;font-weight:400;color:var(--terra);max-width:52%;text-align:center;
  transform:rotate(-3deg);mix-blend-mode:multiply;opacity:.96;word-break:break-word;
  text-shadow:0 1px 1px rgba(120,40,25,.18)}
.engrave-heart{font-family:"Caveat",cursive;font-size:clamp(1.6rem,4.5vw,2.4rem);color:var(--terra);
  margin-top:.15rem;transform:rotate(-3deg);mix-blend-mode:multiply;opacity:.96}
.engrave-heart.hide{display:none}
.stage-note{text-align:center;font-size:.82rem;color:#bcae97;margin-top:.9rem}
.studio-controls{display:flex;flex-direction:column;gap:1.4rem}
.ctl{display:flex;flex-direction:column;gap:.55rem}
.ctl>span{font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;color:#cdbfa6;font-weight:700}
.ctl input[type=text],.ctl select{font-family:var(--sans);font-size:1rem;padding:.85rem 1rem;border-radius:12px;
  border:1.5px solid #4a4136;background:#241f1a;color:var(--cream)}
.ctl input:focus,.ctl select:focus{outline:none;border-color:var(--clay)}
.ctl small{color:#9a8d77;font-size:.78rem}
.swatches{display:flex;gap:.7rem}
.sw{width:36px;height:36px;border-radius:50%;background:var(--c);border:2px solid transparent;cursor:pointer;transition:.2s;box-shadow:inset 0 0 0 2px rgba(0,0,0,.15)}
.sw.is-active{border-color:var(--cream);transform:scale(1.1)}
.toggle{display:flex;align-items:center;gap:.7rem;font-family:var(--sans);font-weight:600;color:var(--cream);
  background:#241f1a;border:1.5px solid #4a4136;border-radius:12px;padding:.8rem 1rem;cursor:pointer;font-size:.95rem}
.toggle span{width:38px;height:22px;border-radius:100px;background:#4a4136;position:relative;transition:.25s;flex:0 0 auto}
.toggle span::after{content:"";position:absolute;top:3px;left:3px;width:16px;height:16px;border-radius:50%;background:var(--cream);transition:.25s}
.toggle.is-active span{background:var(--terra)}
.toggle.is-active span::after{left:19px}
.studio-price{font-family:var(--serif);font-style:italic;color:#e8d9bf;font-size:1.05rem}

/* ====== STORY ====== */
.story{max-width:1180px;margin:0 auto;padding:6.5rem 1.6rem;display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center}
.story-img{border-radius:26px;overflow:hidden;box-shadow:var(--shadow);transform:rotate(-1.4deg)}
.story-img img{width:100%;aspect-ratio:4/4.2;object-fit:cover}
.story-text h2{font-size:clamp(2rem,4.5vw,3.1rem);margin:.4rem 0 1.3rem}
.story-text p{color:var(--ink-soft);margin-bottom:1rem;max-width:34rem}
.story-stats{display:flex;gap:2.5rem;margin-top:2rem}
.story-stats strong{font-family:var(--serif);font-size:1.9rem;display:block;color:var(--clay-deep)}
.story-stats span{font-size:.82rem;color:var(--ink-soft);letter-spacing:.04em}

/* ====== GALLERY ====== */
.gallery{padding:5rem 1.6rem 6.5rem;max-width:1240px;margin:0 auto}
.masonry{columns:3;column-gap:1.3rem}
.masonry img{width:100%;border-radius:14px;margin-bottom:1.3rem;break-inside:avoid;box-shadow:var(--shadow)}

/* ====== CONTACT ====== */
.contact{background:var(--cream-2);padding:6.5rem 1.6rem;border-top:1px solid var(--line)}
.contact-inner{max-width:640px;margin:0 auto}
.order-form{display:flex;flex-direction:column;gap:1.1rem;background:var(--paper);padding:2.4rem;border-radius:var(--radius);border:1px solid var(--line);box-shadow:var(--shadow)}
.order-form .row{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem}
.order-form label{display:flex;flex-direction:column;gap:.4rem;font-weight:700;font-size:.82rem;letter-spacing:.04em;color:var(--ink-soft)}
.order-form input,.order-form textarea{font-family:var(--sans);font-size:1rem;padding:.8rem .95rem;border-radius:11px;
  border:1.5px solid var(--line);background:#fff;color:var(--ink);font-weight:400;resize:vertical}
.order-form input:focus,.order-form textarea:focus{outline:none;border-color:var(--clay)}
.form-alt{text-align:center;font-size:.92rem;color:var(--ink-soft)}
.form-alt a{color:var(--clay-deep);font-weight:700}

/* ====== FOOTER ====== */
.footer{background:var(--ink);color:var(--cream);padding:3.5rem 1.6rem}
.footer-inner{max-width:1100px;margin:0 auto;text-align:center;display:flex;flex-direction:column;align-items:center;gap:1rem}
.footer .brand-name{color:var(--cream)}
.footer .brand-name em{color:#d9b48f}
.footer p{color:#bcae97}
.footer-links{display:flex;gap:1.6rem;flex-wrap:wrap;justify-content:center}
.footer-links a{font-weight:600;color:#d9cdb8}
.footer-links a:hover{color:var(--cream)}
.footer small{color:#8a7e6b}

/* ====== reveal animations ====== */
.reveal,.reveal-img{opacity:0;transform:translateY(26px);transition:opacity .8s ease,transform .8s ease}
.reveal-img{transform:translateY(26px) rotate(1.4deg)}
.story-img.reveal-img{transform:translateY(26px) rotate(-1.4deg)}
.reveal.in,.reveal-img.in{opacity:1;transform:none}
.hero-img.reveal-img.in{transform:rotate(1.4deg)}
.story-img.reveal-img.in{transform:rotate(-1.4deg)}

/* ====== RESPONSIVE ====== */
@media(max-width:900px){
  .hero{grid-template-columns:1fr;padding-top:7rem;gap:2.5rem;text-align:center}
  .hero-sub{margin-left:auto;margin-right:auto}
  .hero-btns{justify-content:center}
  .hero-img{order:-1;max-width:420px;margin:0 auto}
  .grid{grid-template-columns:repeat(2,1fr);gap:1.3rem}
  .studio-wrap,.story{grid-template-columns:1fr;gap:2.5rem}
  .story-img{max-width:440px;margin:0 auto;order:-1}
  .masonry{columns:2}
}
/* mobile menu: full-screen solid overlay that COVERS the page (no overlap),
   shows at 860px so the 6 links never cram into the bar */
@media(max-width:860px){
  .nav-burger{display:flex;z-index:71;position:relative}
  .nav-links{position:fixed;inset:0;width:100vw;max-width:none;height:100vh;
    background:#201b15;
    flex-direction:column;align-items:center;justify-content:center;gap:2rem;padding:2.5rem;
    transform:translateX(100%);transition:transform .35s;z-index:70}
  .nav-links.open{transform:none}
  .nav-links a{font-size:1.55rem;font-family:var(--serif);color:var(--cream)}
  .nav-links a:not(.nav-cta)::after{display:none}
  .nav-links a.nav-cta{background:var(--clay-deep);padding:.6rem 1.7rem;border-radius:100px}
  .nav-burger.open span{background:var(--cream)}
  .nav-burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .nav-burger.open span:nth-child(2){opacity:0}
  .nav-burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
}
/* when the menu is open, HIDE everything on the page except the nav/menu, so
   nothing can ever show through behind it (bulletproof vs any overlay opacity) */
body.menu-open{overflow:hidden}
body.menu-open > *:not(.nav){visibility:hidden}
@media(max-width:620px){
  .grid{grid-template-columns:1fr;max-width:380px;margin:0 auto}
  .masonry{columns:1}
  .order-form .row{grid-template-columns:1fr}
  .order-form{padding:1.6rem}
  .story-stats{gap:1.5rem;justify-content:center}
}

/* ============================================================
   ARTSY LAYER (v2) — hand-drawn art, handwriting, film + insta
   ============================================================ */

/* paper grain over the whole page */
.grain-overlay{position:fixed;inset:0;z-index:1;pointer-events:none;opacity:.5;mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.05'/%3E%3C/svg%3E")}
.nav,.hero,section,.footer{position:relative;z-index:2}

/* handwritten accent label (replaces eyebrow in new sections) */
.script-accent{font-family:var(--hand);font-size:1.7rem;color:var(--clay-deep);
  transform:rotate(-2.5deg);display:inline-block;margin-bottom:.4rem;line-height:1}
.script-accent.light{color:#e6c79a}

/* hand-drawn underline under a key word */
.ink-word{position:relative;color:var(--clay-deep);white-space:nowrap}
.ink-word .underline{position:absolute;left:-2%;bottom:-.32em;width:104%;height:.5em;overflow:visible}
.ink-word .underline path{fill:none;stroke:var(--terra);stroke-width:5;stroke-linecap:round;
  stroke-dasharray:300;stroke-dashoffset:300;transition:stroke-dashoffset 1.1s ease .35s}
.reveal.in .ink-word .underline path,.hero h1.reveal.in .underline path{stroke-dashoffset:0}

/* hand-drawn arrow in hero */
.hand-arrow{width:78px;height:62px;margin-top:1.4rem;margin-left:.5rem;overflow:visible;display:block}
.hand-arrow path{fill:none;stroke:var(--sage-deep);stroke-width:3;stroke-linecap:round;stroke-linejoin:round;opacity:.8}

/* organic blob behind hero */
.hero-blob{position:absolute;z-index:-1;top:-8%;right:-10%;width:60%;height:90%;
  background:radial-gradient(closest-side,rgba(125,148,130,.28),transparent);
  border-radius:60% 40% 55% 45% / 55% 50% 50% 45%;filter:blur(10px)}

/* taped / scrapbook photos */
.hero-photo,.story-photo{position:relative;border-radius:6px;overflow:visible;
  background:#fff;padding:14px 14px 46px;box-shadow:var(--shadow);transform:rotate(1.6deg)}
.story-photo{transform:rotate(-1.8deg)}
.hero-photo img,.story-photo img{width:100%;border-radius:3px;display:block;object-fit:cover}
.hero-photo img{aspect-ratio:4/4.4}.story-photo img{aspect-ratio:4/4.3}
.photo-caption{position:absolute;left:0;right:0;bottom:12px;text-align:center;
  font-family:var(--hand);font-size:1.5rem;color:var(--terra)}
.photo-caption.script{color:var(--clay-deep)}
.tape{position:absolute;width:92px;height:30px;background:rgba(199,160,110,.32);
  border:1px dashed rgba(154,108,72,.35);z-index:3;backdrop-filter:blur(1px)}
.tape-tl{top:-12px;left:18px;transform:rotate(-7deg)}
.tape-br{bottom:30px;right:14px;transform:rotate(6deg)}

/* FILM section */
.film{max-width:1240px;margin:0 auto;padding:6rem 1.6rem}
.film-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.6rem}
.film-card{position:relative;border-radius:16px;overflow:hidden;box-shadow:var(--shadow);background:#1f1b16;aspect-ratio:9/13}
.film-card video{width:100%;height:100%;object-fit:cover;display:block}
.film-card figcaption{position:absolute;left:14px;bottom:12px;font-family:var(--hand);font-size:1.4rem;
  color:#fff;text-shadow:0 1px 6px rgba(0,0,0,.5)}
.film-empty{grid-column:1/-1;text-align:center;color:var(--ink-soft);font-style:italic;padding:2rem}

/* STORY tweaks */
.story-text .signature{font-family:var(--hand);font-size:2.2rem;color:var(--clay-deep);margin:.4rem 0 1.4rem}

/* INSTAGRAM */
.insta{max-width:1240px;margin:0 auto;padding:5rem 1.6rem 6.5rem}
.insta-grid{position:relative;display:grid;grid-template-columns:repeat(3,1fr);gap:.7rem;border-radius:18px;overflow:hidden;cursor:pointer}
.insta-grid img{width:100%;aspect-ratio:1/1;object-fit:cover;transition:transform .5s,filter .5s}
.insta-grid:hover img{filter:brightness(.7) saturate(.9)}
.insta-grid:hover img:hover{transform:scale(1.04);filter:brightness(.85)}
.insta-cta{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:.2rem;font-family:var(--serif);font-size:1.7rem;color:#fff;background:rgba(31,27,22,.32);
  opacity:0;transition:opacity .4s;pointer-events:none;text-shadow:0 2px 14px rgba(0,0,0,.5)}
.insta-grid:hover .insta-cta{opacity:1}
.insta-cta .ig-glyph{font-size:2.4rem}
.insta-cta small{font-family:var(--sans);font-weight:700;font-size:.85rem;letter-spacing:.04em}

/* handwriting for the marquee + price tags */
.marquee-track b{font-style:normal;color:#d9b48f}

@media(max-width:900px){
  .film-grid{grid-template-columns:repeat(2,1fr)}
  .hero-blob{width:90%;opacity:.6}
}
@media(max-width:620px){
  .film-grid{grid-template-columns:1fr;max-width:340px;margin:0 auto}
  .insta-grid{gap:.4rem}
  .script-accent{font-size:1.5rem}
}
