/* ===========================================================
   Aulìa — "Sicilian Light" design system (Direction A)
   Fraunces (display) + Schibsted Grotesk (UI)
   Palette: amber-on-cream + deep olive. WCAG-AA corrected.
   =========================================================== */

:root{
  --cream:#F5EEE1; --cream-2:#EFE4D0; --paper:#FBF7EE;
  --ink:#20241A; --ink-soft:#454A37;
  --olive:#2C3120; --olive-2:#3C4329;
  --amber:#9A5F1E;            /* AA-safe accent: white-on-it 5:1, on-cream 4.8:1 */
  --amber-glow:#D49A43;       /* decorative only (glows, large display) */
  --sage:#62654A;             /* AA-safe muted text */
  --line:rgba(32,36,26,.16);
  --display:'Fraunces',Georgia,'Times New Roman',serif;
  --ui:'Schibsted Grotesk',system-ui,-apple-system,sans-serif;
  color-scheme:light;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}*{animation-duration:.001ms!important;transition-duration:.001ms!important}}
body{
  font-family:var(--ui);background:var(--cream);color:var(--ink);
  line-height:1.55;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{max-width:100%;height:auto;display:block}
a{color:inherit}

/* grain overlay */
body::after{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:9999;opacity:.045;mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

h1,h2,h3,h4{font-family:var(--display);font-weight:400;letter-spacing:-.02em;line-height:1.04;color:var(--ink)}
.serif-it{font-style:italic;font-weight:300}
p{font-size:1rem}

.container{max-width:1240px;margin:0 auto;padding:0 40px}
.container-narrow{max-width:760px;margin:0 auto;padding:0 40px}
.section{padding:96px 0}
.eyebrow{font-size:12px;letter-spacing:.22em;text-transform:uppercase;font-weight:600;color:var(--amber)}
.olive-rule{display:inline-block;width:64px;height:2px;background:var(--amber);margin-top:28px;opacity:.7}

/* fade-in (JS adds .visible) */
.fade-in{opacity:0;transform:translateY(22px);transition:opacity .8s ease,transform .8s ease}
.fade-in.visible{opacity:1;transform:none}

/* ---- buttons ---- */
.btn{font-family:var(--ui);font-size:15px;font-weight:600;border-radius:44px;padding:14px 26px;cursor:pointer;
  text-decoration:none;display:inline-block;transition:transform .15s ease,background .2s ease,color .2s ease;border:1px solid transparent}
.btn:hover{transform:translateY(-2px)}
.btn-lg{padding:16px 30px;font-size:15.5px}
.btn-primary{background:var(--amber);color:#fff;border-color:var(--amber)}
.btn-primary:hover{background:#83501a}
.btn-outline{background:transparent;color:var(--ink);border-color:var(--ink)}
.btn-outline:hover{background:var(--ink);color:var(--cream)}

/* ---- header ---- */
.site-header{position:absolute;top:0;left:0;right:0;z-index:50}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:24px;max-width:1240px;margin:0 auto;padding:26px 40px}
.site-logo{font-family:var(--display);font-size:27px;letter-spacing:.01em;text-decoration:none;color:var(--ink);display:flex;align-items:center;gap:9px}
.site-logo::before{content:"";width:16px;height:16px;background:var(--amber);
  -webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.5'%3E%3Cpath d='M12 21c5-4 8-8 8-12 0 0-5 1-8 5-3-4-8-5-8-5 0 4 3 8 8 12z'/%3E%3Cpath d='M12 21V9'/%3E%3C/svg%3E") center/contain no-repeat;
  mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.5'%3E%3Cpath d='M12 21c5-4 8-8 8-12 0 0-5 1-8 5-3-4-8-5-8-5 0 4 3 8 8 12z'/%3E%3Cpath d='M12 21V9'/%3E%3C/svg%3E") center/contain no-repeat}
.nav-links{display:flex;align-items:center;gap:30px;list-style:none}
.nav-links a{color:var(--ink);text-decoration:none;font-size:14.5px;font-weight:500;opacity:.82;transition:opacity .2s}
.nav-links a:hover{opacity:1}
.lang-switch{font-size:12.5px!important;letter-spacing:.12em;font-weight:600!important;opacity:1!important}
.cart-link{border:1px solid var(--line);border-radius:40px;padding:8px 16px!important;opacity:1!important}
.nav-toggle{display:none;background:none;border:none;color:var(--ink);cursor:pointer;padding:6px}

/* ---- hero ---- */
.hero{position:relative;padding:168px 0 92px;overflow:hidden}
.hero-bg{position:absolute;inset:0;z-index:-1;background:
   radial-gradient(120% 90% at 86% 16%,rgba(212,154,67,.34),transparent 52%),
   radial-gradient(90% 70% at 6% 94%,rgba(98,101,74,.18),transparent 60%),
   linear-gradient(180deg,#F7F1E4,#F1E7D5)}
.hero-overlay{display:none}
.hero-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:30px;align-items:center;max-width:1240px;margin:0 auto;padding:0 40px}
.hero h1{font-size:clamp(44px,6.4vw,90px);max-width:13ch;margin-top:20px}
.hero .lead{font-size:19px;max-width:46ch;margin:26px 0 32px;color:var(--ink-soft)}
.cta-row{display:flex;gap:14px;flex-wrap:wrap}
.trust{margin-top:26px;font-size:12px;letter-spacing:.05em;color:var(--sage);font-weight:600;text-transform:uppercase}
.trust span{margin-right:9px}
.hero-prod{position:relative;display:flex;justify-content:center;align-items:flex-end;min-height:440px}
.glow{position:absolute;width:380px;height:380px;border-radius:50%;top:8%;left:50%;transform:translateX(-50%);filter:blur(8px);
  background:radial-gradient(circle,rgba(212,154,67,.5),rgba(212,154,67,0) 68%)}
.branch{position:absolute;top:2%;right:-4%;width:230px;opacity:.5;color:var(--olive-2)}

/* ---- CSS bottle ---- */
.bottle{position:relative;width:108px;height:330px;filter:drop-shadow(0 24px 28px rgba(40,44,28,.30))}
.bottle .cap{position:absolute;top:0;left:50%;transform:translateX(-50%);width:34px;height:26px;background:linear-gradient(#20241A,#33391f);border-radius:4px 4px 2px 2px}
.bottle .neck{position:absolute;top:24px;left:50%;transform:translateX(-50%);width:26px;height:46px;background:linear-gradient(90deg,#2c3120,#454c2e,#222719)}
.bottle .body{position:absolute;top:64px;left:50%;transform:translateX(-50%);width:100%;height:266px;border-radius:16px 16px 22px 22px;
  background:linear-gradient(100deg,#262b1a 0%,#3f4628 42%,#20241a 64%,#161a0f 100%)}
.bottle .shine{position:absolute;top:74px;left:calc(50% - 40px);width:13px;height:230px;border-radius:8px;background:linear-gradient(rgba(255,247,225,.42),rgba(255,247,225,0));opacity:.6}
.bottle .label{position:absolute;top:150px;left:50%;transform:translateX(-50%);width:84px;height:128px;background:var(--paper);border-radius:3px;display:flex;flex-direction:column;align-items:center;padding:14px 6px 0;text-align:center}
.bottle .label .lb{font-family:var(--display);font-size:16px}
.bottle .label .lc{font-size:7px;letter-spacing:.18em;text-transform:uppercase;color:var(--amber);font-weight:700;margin-top:5px}
.bottle .label .ld{font-size:7px;letter-spacing:.06em;color:var(--ink-soft);margin-top:auto;margin-bottom:12px}
.bottle.lg{width:150px;height:454px}
.bottle.lg .cap{width:46px;height:34px}
.bottle.lg .neck{top:32px;width:34px;height:64px}
.bottle.lg .body{top:88px;height:366px;border-radius:20px 20px 28px 28px}
.bottle.lg .shine{top:104px;left:calc(50% - 56px);height:316px;width:18px}
.bottle.lg .label{top:206px;width:116px;height:178px;padding:20px 8px 0}
.bottle.lg .label .lb{font-size:23px}
.bottle.lg .label .lc{font-size:9px;margin-top:7px}
.bottle.lg .label .ld{font-size:9px;margin-bottom:16px}

/* ---- collection ---- */
.sec-head{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;margin-bottom:52px}
.sec-head h2{font-size:clamp(32px,4vw,52px);max-width:16ch;margin-top:14px}
.sec-head p{max-width:34ch;color:var(--ink-soft);font-size:16px}
.oils{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.oil{background:var(--paper);border:1px solid var(--line);border-radius:18px;padding:40px 30px 30px;display:flex;flex-direction:column;align-items:center;transition:transform .25s ease,box-shadow .25s ease}
.oil:hover{transform:translateY(-6px);box-shadow:0 30px 50px -28px rgba(40,44,28,.45)}
.oil:nth-child(2){transform:translateY(-22px)}
.oil:nth-child(2):hover{transform:translateY(-30px)}
.oil .bottle{margin-bottom:30px}
.oil h3{font-size:25px;text-align:center}
.oil .region{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--amber);font-weight:700;margin:9px 0 14px}
.oil .note{font-size:14.5px;color:var(--ink-soft);text-align:center;font-style:italic;font-family:var(--display);max-width:24ch}
.oil .buy{display:flex;align-items:center;justify-content:space-between;width:100%;margin-top:26px;padding-top:20px;border-top:1px solid var(--line)}
.oil .price{font-family:var(--display);font-size:21px}
.oil .price small{font-family:var(--ui);font-size:12px;color:var(--sage);letter-spacing:.04em}
.oil .add{background:var(--ink);color:var(--cream);border:none;border-radius:40px;padding:11px 20px;font-family:var(--ui);font-size:13.5px;font-weight:600;cursor:pointer;transition:background .2s}
.oil .add:hover{background:var(--amber)}

/* ---- provenance ---- */
.prov{background:var(--olive);color:var(--cream);border-radius:30px;margin:0 40px;padding:80px 64px;position:relative;overflow:hidden}
.prov::before{content:"";position:absolute;top:-30%;right:-6%;width:420px;height:420px;border-radius:50%;background:radial-gradient(circle,rgba(212,154,67,.30),transparent 66%)}
.prov .eyebrow{color:var(--amber-glow)}
.prov h2{color:var(--paper);font-size:clamp(30px,3.8vw,50px);max-width:18ch;margin:16px 0 8px}
.prov .sub{color:rgba(245,238,225,.72);max-width:50ch;font-size:16px;margin-bottom:54px}
.data{display:grid;grid-template-columns:repeat(5,1fr);gap:18px;border-top:1px solid rgba(245,238,225,.18);padding-top:34px}
.data .k{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--amber-glow);font-weight:700;margin-bottom:9px}
.data .v{font-family:var(--display);font-size:23px;color:var(--paper)}
.data .v small{font-family:var(--ui);font-size:12px;color:rgba(245,238,225,.62);display:block;letter-spacing:.02em;margin-top:3px;font-weight:500}

/* ---- trade ---- */
.trade{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:center;background:var(--cream-2);border:1px solid var(--line);border-radius:30px;padding:64px}
.trade h2{font-size:clamp(30px,3.6vw,46px);max-width:15ch}
.trade .eyebrow{margin-bottom:16px;display:block}
.trade p{color:var(--ink-soft);font-size:16.5px;max-width:42ch;margin:18px 0 30px}
.trade ul{list-style:none;margin:0 0 32px}
.trade li{font-size:15px;padding:10px 0;border-bottom:1px solid var(--line);display:flex;align-items:center;gap:12px}
.trade li::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--amber);flex:none}
.trade-card{background:var(--olive);color:var(--paper);border-radius:22px;padding:44px}
.trade-card .eyebrow{color:var(--amber-glow)}
.trade-card h3{font-size:28px;color:var(--paper);margin:12px 0 10px}
.trade-card p{color:rgba(245,238,225,.74);font-size:15px;margin-bottom:26px}
.field{margin-bottom:12px}
.field input{width:100%;background:rgba(245,238,225,.07);border:1px solid rgba(245,238,225,.24);border-radius:40px;padding:14px 18px;color:var(--paper);font-family:var(--ui);font-size:14px}
.field input::placeholder{color:rgba(245,238,225,.55)}
.hp-field{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}

/* ---- forms feedback ---- */
.form-success h3{color:var(--paper)}
.form-error{background:#7a2d22;color:#fff;border-radius:10px;padding:10px 14px;margin-bottom:14px;font-size:14px}

/* ---- footer ---- */
.site-footer{background:var(--olive);color:var(--cream);margin-top:96px;padding:72px 0 34px}
.footer-inner{max-width:1240px;margin:0 auto;padding:0 40px}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:30px;padding-bottom:46px;border-bottom:1px solid rgba(245,238,225,.16)}
.footer-brand{font-family:var(--display);font-size:30px;color:var(--paper);margin-bottom:14px}
.footer-about{color:rgba(245,238,225,.6);font-size:14px;max-width:30ch}
.foot-col h4{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--amber-glow);margin-bottom:16px;font-weight:700}
.foot-col a{display:block;color:rgba(245,238,225,.8);text-decoration:none;font-size:14.5px;padding:6px 0}
.foot-col a:hover{color:var(--paper)}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:24px;font-size:12.5px;color:rgba(245,238,225,.55);flex-wrap:wrap;gap:12px}
.footer-bottom a{color:rgba(245,238,225,.7)}

/* ---- responsive ---- */
@media(max-width:900px){
  .container,.container-narrow,.header-inner,.hero-grid,.footer-inner{padding-left:22px;padding-right:22px}
  .nav-toggle{display:block}
  .nav-links{position:absolute;top:100%;right:22px;left:22px;flex-direction:column;align-items:flex-start;gap:6px;
    background:var(--paper);border:1px solid var(--line);border-radius:16px;padding:18px;display:none;box-shadow:0 24px 50px -24px rgba(40,44,28,.5)}
  .nav-links.open{display:flex}
  .hero{padding:128px 0 64px}
  .hero-grid{grid-template-columns:1fr}
  .hero-prod{order:-1;min-height:330px;margin-bottom:6px}
  .hero h1{font-size:clamp(38px,11vw,60px)}
  .oils{grid-template-columns:1fr;gap:18px}.oil:nth-child(2){transform:none}
  .sec-head{flex-direction:column;align-items:flex-start}
  .prov{margin:0 22px;padding:52px 26px}.data{grid-template-columns:repeat(2,1fr);gap:26px}
  .trade{grid-template-columns:1fr;padding:34px}
  .footer-grid{grid-template-columns:1fr 1fr}
  .section{padding:72px 0}
}

/* ---- shop + product pages ---- */
.page-hero{position:relative;padding:150px 0 40px;overflow:hidden}
.page-title{font-size:clamp(40px,5.4vw,72px);margin-top:14px}
.page-lead{font-size:18px;color:var(--ink-soft);max-width:48ch;margin-top:18px}
.oils-shop{grid-template-columns:repeat(3,1fr)}
.oils-shop .oil:nth-child(2){transform:none}
.oils-shop .oil:nth-child(2):hover{transform:translateY(-6px)}
.oil-link{display:flex;flex-direction:column;align-items:center;text-decoration:none;color:inherit}
.product{padding:150px 0 96px}
.product-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:60px;align-items:center}
.product-visual{position:relative;display:flex;justify-content:center;align-items:center;min-height:460px}
.product-visual .glow{top:14%}
.product-info .eyebrow{display:block;margin-bottom:10px}
.product-info h1{font-size:clamp(40px,5vw,64px)}
.product-note{font-family:var(--display);font-style:italic;font-size:22px;color:var(--ink-soft);margin:18px 0 24px;max-width:30ch}
.product-price{font-family:var(--display);font-size:30px;margin-bottom:26px}
.product-price small{font-family:var(--ui);font-size:14px;color:var(--sage)}
.product-actions{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:40px}
.back-link{display:inline-block;font-size:13px;letter-spacing:.04em;color:var(--amber);text-decoration:none;margin-bottom:18px;font-weight:600}
.product-specs{display:grid;grid-template-columns:repeat(2,1fr);gap:0 40px;border-top:1px solid var(--line)}
.product-specs div{display:flex;justify-content:space-between;gap:16px;padding:14px 0;border-bottom:1px solid var(--line)}
.product-specs dt{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--sage);font-weight:700;align-self:center}
.product-specs dd{font-family:var(--display);font-size:17px;text-align:right}
@media(max-width:900px){
  .oils-shop{grid-template-columns:1fr}
  .product-grid{grid-template-columns:1fr;gap:20px}
  .product-visual{order:-1;min-height:340px}
  .product-specs{grid-template-columns:1fr}
}

/* ---- cart drawer + toast ---- */
.cart-drawer{position:fixed;inset:0;z-index:1000;visibility:hidden;pointer-events:none}
.cart-drawer.open{visibility:visible;pointer-events:auto}
.cart-scrim{position:absolute;inset:0;background:rgba(32,36,26,.42);opacity:0;transition:opacity .3s}
.cart-drawer.open .cart-scrim{opacity:1}
.cart-panel{position:absolute;top:0;right:0;height:100%;width:400px;max-width:92vw;background:var(--paper);
  box-shadow:-20px 0 60px -30px rgba(40,44,28,.6);transform:translateX(100%);transition:transform .32s cubic-bezier(.4,0,.2,1);
  display:flex;flex-direction:column;padding:26px}
.cart-drawer.open .cart-panel{transform:none}
.cart-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}
.cart-head h3{font-size:24px}
.cart-close{background:none;border:none;font-size:30px;line-height:1;color:var(--ink-soft);cursor:pointer;padding:0 4px}
.cart-empty{color:var(--ink-soft);padding:30px 0}
.cart-items{flex:1;overflow-y:auto;margin:0 -4px}
.cart-item{padding:16px 4px;border-bottom:1px solid var(--line)}
.ci-info{display:flex;justify-content:space-between;gap:12px;margin-bottom:8px}
.ci-name{font-family:var(--display);font-size:17px}
.ci-price{color:var(--ink-soft)}
.ci-qty{display:flex;align-items:center;gap:10px}
.ci-dec,.ci-inc{width:28px;height:28px;border:1px solid var(--line);background:transparent;border-radius:50%;cursor:pointer;font-size:16px;line-height:1;color:var(--ink)}
.ci-dec:hover,.ci-inc:hover{background:var(--cream-2)}
.ci-rm{margin-left:auto;background:none;border:none;color:var(--sage);font-size:12px;cursor:pointer;text-decoration:underline}
.cart-foot{padding-top:18px;border-top:1px solid var(--line)}
.cart-sub{display:flex;justify-content:space-between;align-items:baseline;font-size:15px;margin-bottom:4px}
.cart-sub strong{font-family:var(--display);font-size:22px}
.cart-ship{font-size:12px;color:var(--sage);margin-bottom:16px}
.cart-checkout{width:100%;text-align:center}
.cart-toast{position:fixed;bottom:26px;left:50%;transform:translateX(-50%) translateY(20px);z-index:1100;
  background:var(--olive);color:var(--paper);padding:12px 22px;border-radius:40px;font-size:14px;font-weight:600;
  opacity:0;transition:opacity .25s,transform .25s;pointer-events:none}
.cart-toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
@media(max-width:900px){.cart-panel{width:100%;max-width:100%}}

