:root{
  --primary: #1f3b4a;
  --accent: #c9703f;
  --sage: #7c9885;
  --ink: #1a2229;
  --paper: #faf6f0;

  --primary-50: color-mix(in oklch, var(--primary), white 92%);
  --primary-100: color-mix(in oklch, var(--primary), white 82%);
  --primary-200: color-mix(in oklch, var(--primary), white 62%);
  --primary-300: color-mix(in oklch, var(--primary), white 40%);
  --primary-400: color-mix(in oklch, var(--primary), white 20%);
  --primary-600: color-mix(in oklch, var(--primary), black 12%);
  --primary-700: color-mix(in oklch, var(--primary), black 24%);
  --primary-800: color-mix(in oklch, var(--primary), black 36%);

  --accent-100: color-mix(in oklch, var(--accent), white 82%);
  --accent-200: color-mix(in oklch, var(--accent), white 62%);
  --accent-400: color-mix(in oklch, var(--accent), white 15%);
  --accent-600: color-mix(in oklch, var(--accent), black 15%);

  --sage-100: color-mix(in oklch, var(--sage), white 78%);
  --sage-400: color-mix(in oklch, var(--sage), white 10%);

  --paper-100: color-mix(in oklch, var(--paper), white 50%);
  --paper-200: color-mix(in oklch, var(--paper), black 3%);
  --paper-300: color-mix(in oklch, var(--paper), black 7%);

  --ink-soft: color-mix(in oklch, var(--ink), white 30%);
  --ink-softer: color-mix(in oklch, var(--ink), white 52%);

  --radius-sm: .6rem;
  --radius-md: 1.1rem;
  --radius-lg: 1.8rem;
  --radius-xl: 2.6rem;

  --shadow-sm: 0 1px 2px rgba(26,34,41,.07), 0 1px 1px rgba(26,34,41,.05);
  --shadow-md: 0 10px 24px -8px rgba(26,34,41,.16), 0 3px 8px rgba(26,34,41,.07);
  --shadow-lg: 0 28px 56px -16px rgba(26,34,41,.28), 0 10px 20px -6px rgba(26,34,41,.12);

  --space-1: .5rem;
  --space-2: 1rem;
  --space-3: 1.6rem;
  --space-4: 2.6rem;
  --space-5: 4rem;
  --space-6: 6.5rem;

  --font-head: "DM Serif Display", serif;
  --font-body: "DM Sans", sans-serif;
}

*,*::before,*::after{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body.canvas{
  margin:0;
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--paper);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
body.canvas--locked{overflow:hidden;}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
h1,h2,h3{font-family:var(--font-head);font-weight:400;color:var(--primary-800);line-height:1.15;margin:0 0 .5em;}
p{margin:0 0 1em;color:var(--ink-soft);}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0;}

h1{font-size:clamp(2.4rem,5vw + 1rem,4.4rem);}
h2{font-size:clamp(1.9rem,3vw + 1rem,3rem);}
h3{font-size:clamp(1.15rem,1vw + 1rem,1.5rem);}


.btn{
  display:inline-flex;align-items:center;gap:.6em;
  padding:.9rem 1.7rem;
  border-radius:var(--radius-md);
  font-weight:700;font-size:.98rem;
  border:1px solid transparent;
  cursor:pointer;
  transition:transform .25s ease, box-shadow .25s ease, background .25s ease, color .25s ease, border-color .25s ease;
  min-height:44px;
}
.btn--primary{background:var(--primary);color:var(--paper-100);box-shadow:var(--shadow-md);}
.btn--primary:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);background:var(--primary-600);}
.btn--ghost{background:transparent;color:var(--primary-700);border-color:var(--primary-200);}
.btn--ghost:hover{background:var(--primary-50);border-color:var(--primary-300);transform:translateY(-2px);}
.btn--light{background:var(--paper);color:var(--primary-700);box-shadow:var(--shadow-md);}
.btn--light:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);background:var(--paper-100);}


.bridge{
  position:fixed;top:0;left:0;right:0;z-index:500;
  padding:1.1rem 0;
  transition:background .35s ease, box-shadow .35s ease, padding .35s ease;
}
.bridge-inner{
  max-width:1280px;margin:0 auto;padding:0 var(--space-3);
  display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);
}
.bridge-logo{display:flex;align-items:center;gap:.6rem;font-family:var(--font-head);font-size:1.3rem;color:var(--paper);transition:color .35s ease;}
.bridge-nav{display:flex;gap:1.8rem;}
.bridge-nav a{
  font-weight:500;font-size:.98rem;color:var(--paper);opacity:.92;
  position:relative;padding:.3rem 0;transition:color .3s ease, opacity .3s ease;
}
.bridge-nav a::after{
  content:"";position:absolute;left:0;bottom:-2px;width:0;height:2px;background:var(--accent-400);
  transition:width .3s ease;
}
.bridge-nav a:hover,.bridge-nav a.is-active{opacity:1;}
.bridge-nav a:hover::after,.bridge-nav a.is-active::after{width:100%;}
.bridge-cta{
  background:var(--accent);color:#fff;padding:.7rem 1.4rem;border-radius:var(--radius-md);
  font-weight:700;font-size:.92rem;box-shadow:var(--shadow-sm);
  transition:background .3s ease, transform .3s ease;
}
.bridge-cta:hover{background:var(--accent-600);transform:translateY(-2px);}
.bridge-toggle{
  display:none;flex-direction:column;justify-content:center;gap:5px;
  width:44px;height:44px;background:transparent;border:none;cursor:pointer;padding:0;
}
.bridge-toggle span{display:block;width:26px;height:2px;background:var(--paper);border-radius:2px;transition:transform .3s ease, opacity .3s ease, background .3s ease;}

.bridge--solid{
  background:var(--paper);
  box-shadow:var(--shadow-md);
  padding:.7rem 0;
}
.bridge--solid .bridge-logo,.bridge--solid .bridge-nav a{color:var(--primary-800);}
.bridge--solid .bridge-toggle span{background:var(--primary-800);}


.drawer{
  position:fixed;inset:0;z-index:900;
  display:flex;
  transform:translateX(100%);
  transition:transform .5s cubic-bezier(.77,0,.18,1);
}
.drawer--open{transform:translateX(0);}
.drawer-panel{
  width:60%;min-width:0;
  background:var(--primary);
  display:flex;flex-direction:column;justify-content:space-between;
  padding:var(--space-5) var(--space-4);
}
.drawer-nav{display:flex;flex-direction:column;gap:1rem;margin-top:var(--space-5);}
.drawer-nav a{
  font-family:var(--font-head);color:var(--paper);
  font-size:clamp(1.5rem,5vw,2.4rem);
  opacity:.85;transition:opacity .3s ease, padding-left .3s ease;
}
.drawer-nav a:hover{opacity:1;padding-left:.4rem;}
.drawer-foot p{color:var(--paper);opacity:.8;margin:.8rem 0 0;font-size:.9rem;}
.drawer-cta{
  display:inline-flex;background:var(--accent);color:#fff;padding:.8rem 1.4rem;
  border-radius:var(--radius-md);font-weight:700;
}
.drawer-art{width:40%;position:relative;overflow:hidden;}
.drawer-art img{width:100%;height:100%;object-fit:cover;}
.drawer-close{
  position:absolute;top:1.5rem;right:1.5rem;z-index:5;
  width:48px;height:48px;border-radius:50%;
  background:rgba(250,246,240,.15);color:var(--paper);border:1px solid rgba(250,246,240,.4);
  font-size:1.2rem;cursor:pointer;transition:background .3s ease, transform .3s ease;
}
.drawer-close:hover{background:rgba(250,246,240,.3);transform:rotate(90deg);}


.stage{
  position:relative;
  min-height:100vh;
  display:flex;align-items:center;
  padding:calc(var(--space-6) + 2rem) var(--space-3) var(--space-5);
  background:
    radial-gradient(circle at 12% 15%, var(--primary-100), transparent 55%),
    radial-gradient(circle at 88% 82%, var(--accent-100), transparent 50%),
    var(--paper);
}
.stage--page{min-height:70vh;}
.stage-grid{width:100%;max-width:1280px;margin:0 auto;}

.gallery{display:grid;gap:var(--space-3);}
.stage-grid.gallery{
  grid-template-columns:repeat(4,1fr);
  grid-auto-rows:minmax(110px,auto);
}
.cell{
  background:var(--paper);
  border:1px solid var(--paper-300);
  border-radius:var(--radius-lg);
  padding:var(--space-4);
  box-shadow:var(--shadow-sm);
  transition:transform .35s ease, box-shadow .35s ease, border-color .35s ease;
  position:relative;
  display:flex;flex-direction:column;justify-content:center;
}
.cell:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);}
.cell--hero{grid-column:span 2;grid-row:span 2;background:transparent;border:none;box-shadow:none;padding:var(--space-3) var(--space-3) var(--space-3) 0;}
.cell--hero:hover{transform:none;box-shadow:none;}
.cell-eyebrow{
  display:inline-block;font-weight:700;font-size:.82rem;letter-spacing:.08em;text-transform:uppercase;
  color:var(--accent-600);margin-bottom:1rem;
}
.cell-lead{font-size:1.08rem;max-width:52ch;}
.cell-actions{display:flex;flex-wrap:wrap;gap:1rem;margin-top:1.4rem;}
.cell--image{grid-column:span 2;grid-row:span 2;padding:0;overflow:hidden;}
.cell--image img{width:100%;height:100%;object-fit:cover;min-height:280px;border-radius:var(--radius-lg);}
.cell--mini{grid-column:span 1;grid-row:span 1;}
.cell--mini i{font-size:1.5rem;color:var(--accent);margin-bottom:.7rem;}
.cell--mini h3{font-size:1.1rem;margin-bottom:.3rem;}
.cell--mini p{font-size:.92rem;margin:0;}


.gallery-section{max-width:1280px;margin:0 auto;padding:var(--space-6) var(--space-3);}
.gallery-section--tinted{
  max-width:none;
  background:linear-gradient(180deg,var(--primary-50),var(--paper) 70%);
}
.gallery-section--tinted > *{max-width:1280px;margin-left:auto;margin-right:auto;}
.gallery-head{max-width:680px;margin-bottom:var(--space-4);}
.gallery-eyebrow{
  font-weight:700;font-size:.82rem;letter-spacing:.09em;text-transform:uppercase;color:var(--accent-600);
  display:block;margin-bottom:.6rem;
}
.gallery-head h2{margin-bottom:.6rem;}
.gallery-head a{color:var(--primary-700);text-decoration:underline;text-underline-offset:3px;}


.gallery--bento{
  grid-template-columns:repeat(4,1fr);
  grid-auto-rows:minmax(160px,auto);
}
.gallery--bento .cell{grid-column:span 1;}
.cell--wide{grid-column:span 2 !important;}
.cell--tall{grid-column:span 2 !important;grid-row:span 2;padding:0;overflow:hidden;justify-content:flex-end;}
.cell--tall img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0;}
.cell-caption{position:relative;z-index:2;padding:var(--space-4);background:linear-gradient(0deg, rgba(26,34,41,.82), rgba(26,34,41,0) 90%);border-radius:0 0 var(--radius-lg) var(--radius-lg);}
.cell-caption h3,.cell-caption p{color:var(--paper);}
.cell--tall{position:relative;}
.cell--tint{background:var(--primary-50);border-color:var(--primary-100);}
.cell--dark{background:var(--primary-800);border-color:var(--primary-800);}
.cell--dark h3,.cell--dark p{color:var(--paper-100);}
.cell--dark i{color:var(--accent-200);}
.cell i{font-size:1.5rem;color:var(--accent);margin-bottom:.8rem;}


.gallery--steps{grid-template-columns:repeat(4,1fr);}
.cell--step{position:relative;}
.step-number{
  font-family:var(--font-head);font-size:2rem;color:var(--accent-200);display:block;margin-bottom:.4rem;
}
.cell--dark .step-number{color:var(--accent-400);}


.shelf{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-3);}
.shelf--courses{grid-template-columns:repeat(4,1fr);}
.shelf-card{
  position:relative;background:var(--paper);border:1px solid var(--paper-300);border-radius:var(--radius-lg);
  padding:var(--space-3);box-shadow:var(--shadow-sm);overflow:hidden;
  transition:box-shadow .35s ease, transform .35s ease, border-color .35s ease;
}
.shelf-card:hover{box-shadow:var(--shadow-md);transform:translateY(-3px);}
.shelf-card-toggle{
  width:100%;display:flex;align-items:center;gap:.8rem;background:transparent;border:none;
  cursor:pointer;padding:.2rem 0;text-align:left;
}
.shelf-card-toggle i:first-child{font-size:1.4rem;color:var(--accent);}
.shelf-card-toggle h3{margin:0;font-size:1.15rem;flex:1;}
.shelf-card-arrow{color:var(--primary-300);transition:transform .3s ease;}
.shelf-card.is-open .shelf-card-arrow{transform:rotate(180deg);}
.shelf-card-intro{font-size:.94rem;margin:.6rem 0 0;color:var(--ink-softer);}
.shelf-card-more{
  max-height:0;overflow:hidden;transition:max-height .45s ease, opacity .35s ease, margin .35s ease;
  opacity:0;margin-top:0;
}
.shelf-card-more p{font-size:.94rem;margin:0;padding-top:.8rem;border-top:1px solid var(--paper-300);}
.shelf-card.is-open .shelf-card-more{max-height:400px;opacity:1;margin-top:.6rem;}
@media (hover:hover){
  .shelf-card:hover .shelf-card-more{max-height:400px;opacity:1;margin-top:.6rem;}
  .shelf-card:hover .shelf-card-arrow{transform:rotate(180deg);}
}


.spotlight{border-color:var(--accent-200);}
.spotlight::before{
  content:"Nejžádanější";
  position:absolute;top:22px;right:-46px;width:180px;text-align:center;
  transform:rotate(45deg);
  background:var(--accent);color:#fff;
  padding:.35rem 0;font-size:.72rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;
  box-shadow:var(--shadow-sm);
  z-index:3;
}


.situace-swiper{padding-bottom:3rem;}
.slide-card{
  background:var(--paper);border:1px solid var(--paper-300);border-radius:var(--radius-lg);
  padding:var(--space-4);height:100%;box-shadow:var(--shadow-sm);
  transition:box-shadow .35s ease, transform .35s ease;
}
.slide-card:hover{box-shadow:var(--shadow-md);transform:translateY(-4px);}
.slide-card i{font-size:1.6rem;color:var(--accent);margin-bottom:.8rem;}
.swiper-pagination-bullet{background:var(--primary-300);opacity:1;}
.swiper-pagination-bullet-active{background:var(--accent);}


.gallery--contact{grid-template-columns:repeat(4,1fr);}
.contact-card{
  align-items:flex-start;text-align:left;gap:.4rem;
  transition:transform .3s ease, box-shadow .3s ease, background .3s ease;
}
.contact-card i{font-size:1.6rem;color:var(--accent);margin-bottom:.6rem;}
.contact-card h3{margin-bottom:.2rem;}
.contact-card p{margin:0;font-size:.94rem;}
.contact-card:hover{background:var(--primary-50);}
.contact-card--hours{cursor:default;}


.stage--cta{
  min-height:auto;
  padding:var(--space-6) var(--space-3);
  background:linear-gradient(135deg, var(--primary-800), var(--primary) 60%, var(--accent-600));
}
.stage-cta-inner{max-width:720px;margin:0 auto;text-align:center;}
.stage-cta-inner h2{color:var(--paper);}
.stage-cta-inner p{color:var(--paper-100);font-size:1.05rem;}


.gallery--dates{grid-template-columns:repeat(3,1fr);}
.cell--date{flex-direction:row;align-items:flex-start;gap:1.2rem;}
.date-tag{
  flex-shrink:0;width:64px;height:64px;border-radius:var(--radius-md);
  background:var(--primary-800);color:var(--paper);display:flex;flex-direction:column;align-items:center;justify-content:center;
}
.date-tag span{font-size:.72rem;letter-spacing:.06em;font-weight:700;}
.date-tag strong{font-family:var(--font-head);font-size:1rem;}
.date-body h3{font-size:1.05rem;margin-bottom:.3rem;}
.date-body p{font-size:.92rem;margin:0;}
.dates-note{max-width:70ch;margin-top:var(--space-3);color:var(--ink-softer);font-size:.94rem;}


.chat{max-width:640px;margin:0 auto;}
.chat-row{display:flex;margin-bottom:.9rem;}
.chat-row--bot{justify-content:flex-start;}
.chat-row--user{justify-content:flex-end;}
.chat-bubble{
  max-width:80%;padding:1rem 1.3rem;border-radius:var(--radius-lg);
  box-shadow:var(--shadow-sm);
}
.chat-bubble--bot{background:var(--primary-50);border-bottom-left-radius:.3rem;}
.chat-bubble--bot p{margin:0;color:var(--primary-800);font-size:.98rem;}
.chat-bubble--user{background:var(--accent-100);border-bottom-right-radius:.3rem;width:min(100%,420px);}
.chat-bubble--user input[type="text"],
.chat-bubble--user input[type="email"],
.chat-bubble--user textarea{
  width:100%;border:1px solid var(--accent-200);border-radius:var(--radius-sm);
  padding:.7rem .9rem;font-family:var(--font-body);font-size:.98rem;background:var(--paper);
  color:var(--ink);resize:vertical;transition:border-color .3s ease, box-shadow .3s ease;
}
.chat-bubble--user input:focus,.chat-bubble--user textarea:focus{
  outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-100);
}
.chat-bubble--check{background:var(--accent-100);}
.chat-check{display:flex;align-items:flex-start;gap:.6rem;cursor:pointer;font-size:.92rem;color:var(--primary-800);}
.chat-check input{margin-top:.25rem;width:20px;height:20px;flex-shrink:0;accent-color:var(--accent);}
.chat-check a{text-decoration:underline;}
.chat-send{display:flex;justify-content:flex-end;margin-top:1.4rem;}


.map-frame{
  border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-md);border:1px solid var(--paper-300);
}


.stage--thanks{min-height:80vh;justify-content:center;background:radial-gradient(circle at 50% 20%, var(--primary-50), var(--paper) 60%);}
.thanks-box{max-width:520px;margin:0 auto;text-align:center;padding:var(--space-4);}
.check-svg{margin:0 auto 1.5rem;display:block;}
.check-circle{stroke:var(--sage-400);stroke-dasharray:326;stroke-dashoffset:326;animation:drawCircle 1s ease forwards;}
.check-path{stroke:var(--accent);stroke-dasharray:80;stroke-dashoffset:80;animation:drawCheck .5s ease forwards .9s;}
.thanks-heading{opacity:0;animation:fadeUpIn .6s ease forwards 1.3s;}
.thanks-box > p{opacity:0;animation:fadeUpIn .6s ease forwards 1.5s;}
.thanks-box > .btn{opacity:0;animation:fadeUpIn .6s ease forwards 1.7s;}
@keyframes drawCircle{to{stroke-dashoffset:0;}}
@keyframes drawCheck{to{stroke-dashoffset:0;}}
@keyframes fadeUpIn{from{opacity:0;transform:translateY(12px);}to{opacity:1;transform:translateY(0);}}


.doc-stage{padding:calc(var(--space-6) + 1rem) var(--space-3) var(--space-6);max-width:900px;margin:0 auto;}
.doc-wrap h2{margin-top:2.2rem;font-size:1.5rem;}
.doc-wrap p{max-width:75ch;}
.doc-intro{font-size:1.08rem;color:var(--ink-soft);margin-bottom:1rem;}
.doc-letter{
  display:inline-flex;align-items:center;justify-content:center;
  width:2rem;height:2rem;border-radius:50%;background:var(--primary-50);color:var(--primary-700);
  font-family:var(--font-body);font-weight:700;font-size:1rem;margin-right:.6rem;vertical-align:middle;
}
.doc-qa{margin-bottom:1.6rem;padding-bottom:1.6rem;border-bottom:1px solid var(--paper-300);}
.doc-qa:last-child{border-bottom:none;}
.doc-qa h2{margin-top:0;}


.dock{background:var(--primary-800);color:var(--paper-100);margin-top:auto;}
.dock-row{
  max-width:1280px;margin:0 auto;padding:var(--space-4) var(--space-3);
  display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:var(--space-3);
}
.dock-brand{display:flex;align-items:center;gap:.6rem;font-family:var(--font-head);font-size:1.2rem;color:var(--paper);}
.dock-links{display:flex;flex-wrap:wrap;gap:1.2rem;}
.dock-links a{font-size:.9rem;color:var(--paper-100);opacity:.85;transition:opacity .3s ease;}
.dock-links a:hover{opacity:1;text-decoration:underline;}
.dock-contact{display:flex;flex-direction:column;gap:.4rem;font-size:.88rem;}
.dock-contact a,.dock-contact span{display:flex;align-items:center;gap:.5rem;color:var(--paper-100);opacity:.9;}
.dock-contact a:hover{opacity:1;}
.dock-bar{
  border-top:1px solid color-mix(in oklch, var(--paper), transparent 80%);
  padding:1rem var(--space-3);
  display:flex;flex-wrap:wrap;justify-content:space-between;gap:.4rem;
  max-width:1280px;margin:0 auto;font-size:.8rem;opacity:.75;
}
.dock-bar p{margin:0;color:var(--paper-100);}


.stage-curtain{
  position:fixed;inset:0;background:rgba(20,26,31,.5);z-index:998;
  opacity:0;pointer-events:none;transition:opacity .4s ease;
}
.stage-curtain--visible{opacity:1;pointer-events:auto;}
.cookie-drawer{
  position:fixed;top:0;right:0;width:min(300px,88vw);height:100vh;z-index:999;
  background:var(--paper);box-shadow:var(--shadow-lg);
  transform:translateX(100%);transition:transform .45s cubic-bezier(.77,0,.18,1);
  overflow-y:auto;padding:var(--space-4) var(--space-3);
  display:flex;flex-direction:column;gap:var(--space-3);
}
.cookie-drawer--open{transform:translateX(0);}
.cookie-drawer-icon{font-size:1.8rem;color:var(--accent);}
.cookie-drawer h2{font-size:1.3rem;margin-bottom:.4rem;}
.cookie-drawer p{font-size:.88rem;color:var(--ink-softer);}
.cookie-cat{display:flex;align-items:center;justify-content:space-between;padding:.7rem 0;border-top:1px solid var(--paper-300);}
.cookie-cat:last-of-type{border-bottom:1px solid var(--paper-300);}
.cookie-cat-label{font-size:.92rem;font-weight:700;color:var(--primary-800);}
.cookie-cat-desc{font-size:.78rem;color:var(--ink-softer);margin:.15rem 0 0;}
.switch{position:relative;display:inline-block;width:44px;height:24px;flex-shrink:0;}
.switch input{opacity:0;width:0;height:0;}
.switch-slider{
  position:absolute;cursor:pointer;inset:0;background:var(--primary-200);border-radius:999px;
  transition:background .3s ease;
}
.switch-slider::before{
  content:"";position:absolute;width:18px;height:18px;left:3px;top:3px;background:#fff;border-radius:50%;
  transition:transform .3s ease;box-shadow:var(--shadow-sm);
}
.switch input:checked + .switch-slider{background:var(--accent);}
.switch input:checked + .switch-slider::before{transform:translateX(20px);}
.switch input:disabled + .switch-slider{opacity:.6;cursor:not-allowed;}
.cookie-actions{display:flex;flex-direction:column;gap:.6rem;margin-top:auto;padding-top:1rem;}
.cookie-actions button{
  width:100%;padding:.8rem;border-radius:var(--radius-md);font-weight:700;font-size:.88rem;
  cursor:pointer;border:1px solid transparent;transition:transform .25s ease, background .25s ease;
  min-height:44px;
}
.cookie-accept-all{background:var(--primary);color:var(--paper);}
.cookie-accept-all:hover{background:var(--primary-600);transform:translateY(-2px);}
.cookie-save{background:var(--paper-200);color:var(--primary-800);border-color:var(--paper-300);}
.cookie-save:hover{background:var(--paper-300);}
.cookie-reject{background:transparent;color:var(--ink-softer);}
.cookie-reject:hover{color:var(--ink);}


@media (max-width:1024px){
  .stage-grid.gallery,.gallery--bento,.gallery--steps,.gallery--contact,.shelf,.shelf--courses,.gallery--dates{
    grid-template-columns:repeat(2,1fr);
  }
  .cell--hero,.cell--image{grid-column:span 2;}
  .cell--wide{grid-column:span 2 !important;}
  .cell--tall{grid-column:span 2 !important;}
}
@media (max-width:860px){
  .bridge-nav,.bridge-cta{display:none;}
  .bridge-toggle{display:flex;}
  .drawer-panel{width:58%;padding:var(--space-4) var(--space-3);}
  .drawer-art{width:42%;}
}
@media (max-width:640px){
  .stage-grid.gallery,.gallery--bento,.gallery--steps,.gallery--contact,.shelf,.shelf--courses,.gallery--dates{
    grid-template-columns:1fr;
  }
  .cell--hero,.cell--image,.cell--wide,.cell--tall{grid-column:span 1 !important;}
  .cell--tall{grid-row:span 1;min-height:260px;}
  .stage{padding-top:8rem;}
  .dock-row{flex-direction:column;align-items:flex-start;}
  .dock-bar{flex-direction:column;}
  .cell--date{flex-direction:column;}
  .drawer-panel{width:62%;}
  .drawer-art{width:38%;}
  .drawer-nav a{font-size:1.5rem;}
  .spotlight::before{right:-50px;width:170px;font-size:.66rem;}
}
@media (max-width:400px){
  .drawer-panel{width:66%;padding:var(--space-3) 1rem;}
  .drawer-art{width:34%;}
  .drawer-nav a{font-size:1.25rem;}
}