/*
Theme Name: Quobble
Theme URI: https://quobble.ca
Author: Quobble
Description: Conversion landing-page theme for Quobble — AI automation for small business. Warm editorial design with a built-in audit lead form.
Version: 1.0.0
Requires at least: 6.0
Requires PHP: 7.4
License: GNU General Public License v2 or later
Text Domain: quobble
*/

:root{
  --cream:#FBF6EC;
  --paper:#F3EAD7;
  --paper-edge:#E8DCC2;
  --ink:#1C1A16;
  --ink-soft:#55503F;
  --orange:#FF4A1C;
  --orange-deep:#D8390F;
  --moss:#1F6F57;
  --shadow:rgba(28,26,22,.14);
  --radius:18px;
  --maxw:1120px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:"Hanken Grotesk",sans-serif;
  background:var(--cream);
  color:var(--ink);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  position:relative;
}
/* grain overlay */
body::after{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:9999;opacity:.4;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='.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.045'/%3E%3C/svg%3E");
}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 clamp(20px,5vw,48px)}

h1,h2,h3,.display{font-family:"Fraunces",serif;font-weight:600;line-height:1.02;letter-spacing:-.015em}

a{color:inherit;text-decoration:none}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.6em;
  font-weight:600;font-size:1.02rem;
  padding:.95em 1.6em;border-radius:100px;border:none;cursor:pointer;
  background:var(--orange);color:#fff;
  box-shadow:0 .5em 0 0 var(--orange-deep);
  transition:transform .14s ease, box-shadow .14s ease;
  font-family:"Hanken Grotesk",sans-serif;
}
.btn:hover{transform:translateY(-2px);box-shadow:0 .7em 0 0 var(--orange-deep)}
.btn:active{transform:translateY(.5em);box-shadow:0 0 0 0 var(--orange-deep)}
.btn.ghost{background:transparent;color:var(--ink);box-shadow:inset 0 0 0 2px var(--ink)}
.btn.ghost:hover{background:var(--ink);color:var(--cream)}
.btn .arrow{transition:transform .2s ease}
.btn:hover .arrow{transform:translateX(4px)}

/* ---------- header ---------- */
header{position:sticky;top:0;z-index:100;background:color-mix(in srgb,var(--cream) 86%, transparent);backdrop-filter:blur(8px);border-bottom:1px solid var(--paper-edge)}
.nav{display:flex;align-items:center;justify-content:space-between;padding:16px clamp(20px,5vw,48px);max-width:var(--maxw);margin:0 auto}
.logo{font-family:"Fraunces",serif;font-weight:600;font-size:1.6rem;letter-spacing:-.02em;display:flex;align-items:center;gap:.05em}
.logo .bob{display:inline-block;color:var(--orange)}
.logo .bob.b1{animation:bob 2.6s ease-in-out infinite}
.logo .bob.b2{animation:bob 2.6s ease-in-out infinite .2s}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(-4px)}}
.nav .btn{padding:.6em 1.15em;font-size:.92rem;box-shadow:0 .35em 0 0 var(--orange-deep)}
@media(max-width:620px){.nav-cta-text-long{display:none}}

/* ---------- hero ---------- */
.hero{position:relative;padding:clamp(56px,9vw,110px) 0 clamp(40px,6vw,70px);overflow:hidden}
.hero-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:clamp(30px,5vw,64px);align-items:center}
@media(max-width:880px){.hero-grid{grid-template-columns:1fr;gap:36px}}

.eyebrow{display:inline-flex;align-items:center;gap:.5em;font-size:.82rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--moss);background:color-mix(in srgb,var(--moss) 12%,transparent);padding:.45em .9em;border-radius:100px;margin-bottom:24px}
.eyebrow .dot{width:7px;height:7px;border-radius:50%;background:var(--moss);animation:pulse 1.8s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}

h1.hero-title{font-size:clamp(2.6rem,6.4vw,4.6rem);margin-bottom:24px}
h1.hero-title em{font-style:italic;color:var(--orange);position:relative;white-space:nowrap}
h1.hero-title em::after{content:"";position:absolute;left:0;right:0;bottom:.04em;height:.12em;background:var(--orange);opacity:.28;border-radius:4px}
.hero-sub{font-size:clamp(1.1rem,2vw,1.32rem);color:var(--ink-soft);max-width:30ch;margin-bottom:34px}
.hero-cta-row{display:flex;flex-wrap:wrap;gap:14px;align-items:center}
.hero-note{font-size:.92rem;color:var(--ink-soft);margin-top:18px;display:flex;align-items:center;gap:.5em}
.hero-note svg{flex:none}

/* hero card / visual */
.hero-card{background:var(--ink);color:var(--cream);border-radius:var(--radius);padding:30px;box-shadow:0 30px 60px -20px var(--shadow);position:relative;transform:rotate(1.4deg)}
.hero-card h3{font-size:1.05rem;font-family:"Hanken Grotesk";font-weight:600;color:#b9b2a0;letter-spacing:.04em;margin-bottom:18px;text-transform:uppercase}
.task{display:flex;align-items:center;gap:12px;padding:13px 0;border-bottom:1px solid rgba(255,255,255,.1);font-size:1.02rem}
.task:last-child{border-bottom:none}
.task .tick{width:24px;height:24px;border-radius:50%;background:var(--orange);display:grid;place-items:center;flex:none;animation:none}
.task.done span{color:#8e887a;text-decoration:line-through;text-decoration-color:var(--orange)}
.task .tick svg{width:13px;height:13px}
.stamp{position:absolute;top:-18px;right:-14px;background:var(--orange);color:#fff;font-family:"Fraunces";font-weight:600;font-size:.95rem;padding:.5em .9em;border-radius:100px;transform:rotate(8deg);box-shadow:0 8px 0 var(--orange-deep)}

/* ---------- section frame ---------- */
section{padding:clamp(54px,8vw,96px) 0}
.section-head{max-width:620px;margin-bottom:clamp(34px,5vw,56px)}
.section-head .kicker{font-weight:700;letter-spacing:.14em;text-transform:uppercase;font-size:.8rem;color:var(--orange);margin-bottom:14px}
.section-head h2{font-size:clamp(2rem,4.4vw,3.1rem)}
.section-head p{font-size:1.12rem;color:var(--ink-soft);margin-top:16px}

/* problem grid */
.prob{background:var(--paper);border-top:1px solid var(--paper-edge);border-bottom:1px solid var(--paper-edge)}
.prob-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px}
.prob-item{background:var(--cream);border:1px solid var(--paper-edge);border-radius:14px;padding:22px 22px 24px;transition:transform .2s ease, box-shadow .2s ease}
.prob-item:hover{transform:translateY(-4px);box-shadow:0 16px 30px -16px var(--shadow)}
.prob-item .ico{font-size:1.7rem;margin-bottom:12px;display:block}
.prob-item h4{font-family:"Hanken Grotesk";font-weight:700;font-size:1.08rem;margin-bottom:5px}
.prob-item p{font-size:.96rem;color:var(--ink-soft)}

/* steps */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(18px,3vw,34px);counter-reset:s}
@media(max-width:780px){.steps{grid-template-columns:1fr;gap:14px}}
.step{position:relative;padding:34px 26px 30px;border-radius:var(--radius);background:var(--cream);border:2px solid var(--ink);box-shadow:6px 6px 0 var(--ink)}
.step:nth-child(2){background:var(--ink);color:var(--cream);box-shadow:6px 6px 0 var(--orange)}
.step:nth-child(2) p{color:#cfc7b6}
.step::before{counter-increment:s;content:"0" counter(s);font-family:"Fraunces";font-weight:600;font-size:2.4rem;color:var(--orange);display:block;margin-bottom:14px;line-height:1}
.step h3{font-size:1.4rem;margin-bottom:10px}
.step p{color:var(--ink-soft);font-size:1rem}

/* proof / why */
.why{background:var(--ink);color:var(--cream)}
.why .section-head h2{color:var(--cream)}
.why .section-head .kicker{color:var(--orange)}
.why-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(30px,5vw,60px);align-items:start}
@media(max-width:820px){.why-grid{grid-template-columns:1fr;gap:34px}}
.why-list{list-style:none;display:flex;flex-direction:column;gap:20px}
.why-list li{display:flex;gap:16px;align-items:flex-start;font-size:1.08rem}
.why-list .tick{flex:none;width:30px;height:30px;border-radius:9px;background:var(--orange);display:grid;place-items:center;margin-top:2px}
.why-list .tick svg{width:16px;height:16px}
.why-list b{font-weight:700}
.why-list span{color:#cfc7b6}
.quote{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.12);border-radius:var(--radius);padding:30px}
.quote .big{font-family:"Fraunces";font-style:italic;font-size:1.5rem;line-height:1.3;margin-bottom:18px}
.quote .who{font-size:.95rem;color:#a59e8d}
.promise-eyebrow{font-family:"Hanken Grotesk";font-weight:700;letter-spacing:.12em;text-transform:uppercase;font-size:.78rem;color:var(--orange);margin-bottom:14px}
.promise-title{font-family:"Fraunces";font-weight:600;font-size:1.5rem;line-height:1.2;margin-bottom:20px}
.promise-list{list-style:none;display:flex;flex-direction:column;gap:14px}
.promise-list li{display:flex;gap:13px;align-items:flex-start;font-size:1.04rem;color:#e9e3d4}
.promise-list .tick{flex:none;width:26px;height:26px;border-radius:8px;background:var(--orange);display:grid;place-items:center;margin-top:1px}
.promise-list .tick svg{width:14px;height:14px}

/* ---------- form / offer ---------- */
.offer{background:var(--orange);color:#fff;position:relative;overflow:hidden}
.offer::before{content:"";position:absolute;width:540px;height:540px;border-radius:50%;background:var(--orange-deep);opacity:.4;top:-180px;right:-160px}
.offer-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,5vw,64px);align-items:center;position:relative}
@media(max-width:880px){.offer-grid{grid-template-columns:1fr;gap:34px}}
.offer h2{font-size:clamp(2.1rem,4.6vw,3.3rem);color:#fff;margin-bottom:18px}
.offer .lead{font-size:1.18rem;color:#ffe7df;max-width:34ch;margin-bottom:24px}
.offer-points{list-style:none;display:flex;flex-direction:column;gap:12px}
.offer-points li{display:flex;gap:11px;align-items:center;font-weight:500}
.offer-points svg{flex:none}

.form-card{background:var(--cream);color:var(--ink);border-radius:22px;padding:clamp(24px,3.5vw,38px);box-shadow:0 40px 70px -25px rgba(0,0,0,.4)}
.form-card h3{font-size:1.5rem;margin-bottom:6px}
.form-card .sub{color:var(--ink-soft);font-size:.98rem;margin-bottom:22px}
.field{margin-bottom:16px}
.field label{display:block;font-weight:600;font-size:.9rem;margin-bottom:6px}
.field input,.field select,.field textarea{
  width:100%;font-family:inherit;font-size:1rem;padding:13px 15px;border-radius:12px;
  border:2px solid var(--paper-edge);background:#fff;color:var(--ink);transition:border-color .15s ease, box-shadow .15s ease;
}
.field textarea{resize:vertical;min-height:84px}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--orange);box-shadow:0 0 0 4px color-mix(in srgb,var(--orange) 18%,transparent)}
.form-card .btn{width:100%;justify-content:center;margin-top:6px}
.form-fine{font-size:.8rem;color:var(--ink-soft);margin-top:14px;text-align:center}
.form-success{display:none;text-align:center;padding:20px 0}
.form-success.show{display:block;animation:pop .4s ease}
@keyframes pop{from{transform:scale(.9);opacity:0}to{transform:scale(1);opacity:1}}
.form-success .big-tick{width:64px;height:64px;border-radius:50%;background:var(--moss);display:grid;place-items:center;margin:0 auto 16px}
.form-success h3{font-size:1.6rem;margin-bottom:8px}
.form-success p{color:var(--ink-soft)}

/* footer */
footer{background:var(--cream);padding:46px 0 40px;border-top:1px solid var(--paper-edge)}
.foot-grid{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:18px}
.foot-grid .logo{font-size:1.4rem}
.foot-links{display:flex;gap:24px;font-size:.95rem;color:var(--ink-soft)}
.foot-links a:hover{color:var(--orange)}
.copy{width:100%;font-size:.85rem;color:var(--ink-soft);border-top:1px solid var(--paper-edge);margin-top:30px;padding-top:22px}

/* reveal animation — progressive enhancement: visible by default, only hidden when JS is active */
.reveal{transition:opacity .7s cubic-bezier(.2,.7,.2,1),transform .7s cubic-bezier(.2,.7,.2,1)}
html.js .reveal{opacity:0;transform:translateY(26px)}
html.js .reveal.in{opacity:1;transform:none}
.stagger>*{opacity:0;transform:translateY(20px);animation:rise .7s cubic-bezier(.2,.7,.2,1) forwards}
.stagger>*:nth-child(1){animation-delay:.05s}.stagger>*:nth-child(2){animation-delay:.15s}
.stagger>*:nth-child(3){animation-delay:.25s}.stagger>*:nth-child(4){animation-delay:.35s}
@keyframes rise{to{opacity:1;transform:none}}
@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}.reveal{opacity:1;transform:none}.stagger>*{opacity:1;transform:none}}

/* privacy page */
.pp-main{max-width:760px;margin:0 auto;padding:clamp(40px,7vw,72px) clamp(20px,5vw,40px) 80px}
.pp-main h1{font-size:clamp(2.2rem,5vw,3rem);margin-bottom:10px}
.pp-updated{color:var(--ink-soft);font-size:.95rem;margin-bottom:36px}
.pp-main h2{font-size:1.45rem;margin:34px 0 10px}
.pp-main p,.pp-main li{color:#322f28;font-size:1.04rem;margin-bottom:12px;line-height:1.65}
.pp-main ul{padding-left:1.2em;margin-bottom:12px}
.pp-main li{margin-bottom:6px}
.pp-main a{color:var(--orange-deep);font-weight:600}
.pp-main a:hover{text-decoration:underline}
