/* ---------- Custom fonts (loaded from ./fonts/ next to this HTML) ---------- */
@font-face{font-family:"SF Comic Script";src:url("fonts/SF Comic Script.ttf") format("truetype");font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:"SF Comic Script";src:url("fonts/SF Comic Script Bold.ttf") format("truetype");font-weight:700;font-style:normal;font-display:swap}
@font-face{font-family:"SF Comic Script Cond";src:url("fonts/SF Comic Script Condensed.ttf") format("truetype");font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:"SF Comic Script Ext";src:url("fonts/SF Comic Script Extended.ttf") format("truetype");font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:"Gallaudet";src:url("fonts/GallaudetRegular-qZe1.ttf") format("truetype");font-weight:400;font-style:normal;font-display:swap}

:root{
  /* Deep-blue dominant night sky. ~20% darker, ~20% more saturated than baseline. */
  --night-0:#00041a;
  --night-1:#000c33;
  --night-2:#001f5e;
  --night-3:#003684;
  --paper:#e6f0ff;
  --paper-dim:#86a3d6;
  --hairline:rgba(134,163,214,0.20);
  --hairline-strong:rgba(134,163,214,0.38);

  --cyan:#22d3ee;
  --teal:#14b8a6;
  --lime:#a3e635;
  --magenta:#ec4899;
  --ember:#fb923c;
  --ember-bright:#f97316;
  --purple:#7c3aed;

  /* per-book pairs — pull from each book's own cover energy */
  --eyeth-a:#22d3ee;   --eyeth-b:#14b8a6;
  --mmmak-a:#14b8a6;   --mmmak-b:#a3e635;
  --mmtf-a:#fb923c;    --mmtf-b:#ec4899;

  /* type stack */
  --font-display:"SF Comic Script","Comic Sans MS",cursive,sans-serif;
  --font-deaf:"Gallaudet",Georgia,serif;
  --font-body:Arial,"Helvetica Neue",Helvetica,sans-serif;
}

*{box-sizing:border-box;margin:0;padding:0}
html{
  background:
    radial-gradient(1200px 800px at 78% -8%, rgba(20,184,166,0.16), transparent 65%),
    radial-gradient(1000px 700px at 8% 105%, rgba(34,211,238,0.14), transparent 60%),
    radial-gradient(800px 600px at 92% 92%, rgba(236,72,153,0.07), transparent 60%),
    radial-gradient(600px 460px at 30% 60%, rgba(163,230,53,0.04), transparent 70%),
    linear-gradient(180deg, #00041a 0%, #000c33 30%, #001f5e 65%, #003684 100%);
  background-attachment:fixed;
  background-size:cover;
  background-color:#00041a;
  min-height:100%;
}
html,body{color:var(--paper);font-family:var(--font-body);font-size:17px;line-height:1.55;-webkit-font-smoothing:antialiased}
body{min-height:100vh;overflow-x:hidden;position:relative;background:transparent}

.sky{display:none}
.stars{position:fixed;inset:0;z-index:-1;pointer-events:none;overflow:hidden}
.star{
  position:absolute;background:#fff;border-radius:50%;
  animation:twinkle var(--dur,4s) ease-in-out infinite;
  animation-delay:var(--delay,0s);opacity:0;
  box-shadow:0 0 6px rgba(255,255,255,0.45);
}
@keyframes twinkle{0%,100%{opacity:0.1}50%{opacity:var(--peak,0.9)}}
.aurora{position:fixed;inset:-20%;z-index:-1;pointer-events:none;filter:blur(80px);opacity:0.26}
.aurora::before,.aurora::after{
  content:"";position:absolute;width:60%;height:50%;border-radius:50%;
  background:radial-gradient(closest-side, var(--cyan), transparent);
  top:5%;left:10%;
  animation:drift 22s ease-in-out infinite alternate;
}
.aurora::after{
  background:radial-gradient(closest-side, var(--teal), transparent);
  top:30%;left:55%;width:55%;height:45%;
  animation-duration:28s;animation-delay:-8s;
}
@keyframes drift{from{transform:translate(0,0) scale(1)} to{transform:translate(-6%,4%) scale(1.12)}}

a{color:var(--paper);text-decoration:none}
.wrap{max-width:1240px;margin:0 auto;padding:0 28px}

/* ---------- Header ---------- */
header.site{
  position:sticky;top:0;z-index:50;
  backdrop-filter:blur(14px);
  background:rgba(3,5,26,0.55);
  border-bottom:1px solid var(--hairline);
}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding:14px 28px;gap:20px}
.header-right{display:flex;align-items:center;gap:14px}
.brand{display:flex;align-items:center;gap:12px;min-width:0}
a.brand{text-decoration:none;cursor:pointer}
.brand-mark{
  width:44px;height:44px;object-fit:contain;flex-shrink:0;
  filter:drop-shadow(0 0 10px rgba(34,211,238,0.30));
}
.brand-text{
  font-family:var(--font-display);font-weight:700;
  letter-spacing:0.02em;text-transform:uppercase;font-size:20px;line-height:1;
  background:linear-gradient(90deg,var(--cyan),var(--teal),var(--lime));
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.brand-text small{display:block;font-family:var(--font-body);font-size:10px;letter-spacing:0.32em;color:var(--paper-dim);-webkit-text-fill-color:var(--paper-dim);background:none;margin-top:4px;font-weight:700;text-transform:uppercase}

nav.socials{display:flex;align-items:center;gap:8px}
nav.socials a{
  display:inline-flex;align-items:center;justify-content:center;
  width:36px;height:36px;border-radius:50%;
  background:rgba(255,255,255,0.04);border:1px solid var(--hairline-strong);
  transition:transform .2s ease,border-color .2s,background .2s,box-shadow .2s;
}
nav.socials a:hover{
  transform:translateY(-1px);
  border-color:var(--cyan);background:rgba(34,211,238,0.10);
  box-shadow:0 0 0 4px rgba(34,211,238,0.08);
}
nav.socials a img{width:18px;height:18px;object-fit:contain;display:block}

@media (max-width:760px){
  nav.socials{display:none}
  .brand-text{font-size:16px}
  .brand-mark{width:36px;height:36px}
}

/* ---------- Locale switcher ---------- */
.locale{
  position:relative;display:inline-flex;align-items:center;gap:10px;
  padding:10px 16px;border-radius:999px;
  background:rgba(255,255,255,0.04);border:1px solid var(--hairline-strong);
  cursor:pointer;user-select:none;
  font-family:var(--font-body);font-size:13px;font-weight:500;
  transition:border-color .2s,background .2s,box-shadow .2s;
}
.locale:hover{border-color:var(--cyan);box-shadow:0 0 0 4px rgba(34,211,238,0.08)}
.locale .flag{font-size:18px;line-height:1}
.locale .chev{opacity:0.7;font-size:10px;margin-left:2px}
.locale .lbl b{color:var(--paper);font-weight:600}
.locale .lbl span{color:var(--paper-dim);margin-left:6px}
.locale-panel{
  position:absolute;top:calc(100% + 10px);right:0;width:min(360px,90vw);
  background:rgba(2,15,50,0.97);backdrop-filter:blur(14px);
  border:1px solid var(--hairline-strong);border-radius:14px;
  padding:14px;display:none;z-index:60;
  box-shadow:0 20px 60px rgba(0,0,0,0.6),0 0 0 1px rgba(34,211,238,0.18);
}
.locale-panel.open{display:block}
.locale-panel h4{font-family:var(--font-body);font-size:11px;letter-spacing:0.22em;text-transform:uppercase;color:var(--paper-dim);font-weight:500;margin-bottom:10px;padding:0 6px}
.locale-grid{display:grid;grid-template-columns:1fr 1fr;gap:4px}
.locale-option{
  display:flex;align-items:center;gap:10px;padding:9px 10px;border-radius:8px;cursor:pointer;
  transition:background .15s;font-size:13px;
}
.locale-option:hover{background:rgba(34,211,238,0.10)}
.locale-option.active{background:rgba(34,211,238,0.18);outline:1px solid rgba(34,211,238,0.45)}
.locale-option .f{font-size:18px}
.locale-option .t b{display:block;font-weight:600;color:var(--paper);font-size:13px;line-height:1.2}
.locale-option .t span{font-size:11px;color:var(--paper-dim)}

/* ---------- Hero ---------- */
.hero{padding:44px 0 32px;text-align:center;position:relative}
.kicker{
  display:inline-block;padding:6px 14px;border-radius:999px;
  border:1px solid var(--hairline-strong);
  font-family:var(--font-body);font-size:10px;font-weight:700;letter-spacing:0.26em;text-transform:uppercase;color:var(--paper-dim);
  margin-bottom:16px;
}
.kicker .pulse{display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--cyan);box-shadow:0 0 10px var(--cyan);margin-right:8px;vertical-align:middle;animation:pulse 2.4s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:0.4}50%{opacity:1}}
h1.hero-title{
  font-family:var(--font-display);font-weight:700;font-style:normal;
  font-size:clamp(32px,4.6vw,58px);line-height:1.0;letter-spacing:0.005em;
  text-transform:uppercase;
  max-width:24ch;margin:0 auto;
  text-shadow:0 4px 40px rgba(34,211,238,0.22);
}
h1.hero-title em{font-style:normal;background:linear-gradient(90deg,var(--cyan),var(--lime),var(--teal));-webkit-background-clip:text;background-clip:text;color:transparent;font-weight:700}

/* ASL signature — two rows letter-aligned via grid, gradient sliced per-letter via --idx */
.hero .signature{margin:24px auto 0;display:inline-flex;flex-direction:column;gap:6px}
.hero .sig-row{display:grid;grid-template-columns:repeat(15, 1fr);align-items:center;width:100%}
.hero .sig-row span{
  display:flex;align-items:center;justify-content:center;text-align:center;line-height:1;
  background:linear-gradient(90deg, var(--cyan), var(--teal));
  background-size:1500% 100%;
  background-position-x:calc(var(--idx, 0) / 14 * 100%);
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;color:transparent;
  /* Dock-style magnification: JS sets transform: scale(N) on hover proximity.
     Springy easing gives that Apple-dock bounce. Grid cell width stays fixed (1fr),
     so the line's total length stays constant — letters just visually swell.
     A yellow drop-shadow halo fades in, and the gradient fill cross-fades to white,
     all on the same 0.3s springy timing tied to hover proximity. */
  transition:transform 0.30s cubic-bezier(0.34, 1.56, 0.64, 1),
             filter    0.30s cubic-bezier(0.34, 1.56, 0.64, 1),
             -webkit-text-fill-color 0.30s cubic-bezier(0.34, 1.56, 0.64, 1),
             color     0.30s cubic-bezier(0.34, 1.56, 0.64, 1);
  transform-origin:center;
  will-change:transform, filter;
}
/* Give the dock effect a little vertical breathing room so scaled letters don't push the lede */
.hero .signature{padding:14px 0}
.hero .sig-asl span{
  font-family:var(--font-deaf);font-weight:400;
  font-size:clamp(54px,8vw,96px);
  text-shadow:0 0 32px rgba(34,211,238,0.22);
}
.hero .sig-readable span{
  font-family:var(--font-display);font-weight:700;
  font-size:clamp(28px,2.8vw,40px);letter-spacing:0.02em;
}

.hero p.lede{margin:14px auto 0;max-width:60ch;color:var(--paper-dim);font-size:15px;line-height:1.5}
.locale-now{
  margin-top:18px;display:inline-flex;align-items:center;gap:10px;
  font-family:var(--font-body);font-size:11px;letter-spacing:0.2em;text-transform:uppercase;color:var(--paper-dim);
}
.locale-now b{color:var(--paper);font-weight:600;letter-spacing:0.18em}
.locale-now u{
  cursor:pointer;text-decoration:none;border-bottom:1px dashed var(--cyan);color:var(--cyan);
  padding-bottom:2px;transition:color .2s;
}
.locale-now u:hover{color:var(--magenta);border-color:var(--magenta)}

/* ---------- Locale bar — two side-by-side custom dropdowns (Country + Language) ---------- */
.locale-bar{padding:24px 0 6px}
.locale-bar-card{
  border-radius:18px;
  background:linear-gradient(180deg, rgba(255,255,255,0.025), rgba(255,255,255,0.01));
  border:1px solid var(--hairline);
  padding:22px 26px;
  display:grid;grid-template-columns:1fr 1fr;gap:26px;
}
@media (max-width:760px){
  .locale-bar-card{grid-template-columns:1fr;gap:16px;padding:18px}
}
.locale-picker{display:flex;flex-direction:column;gap:10px;position:relative}
.locale-picker-label{
  font-family:var(--font-body);font-weight:700;
  font-size:11px;letter-spacing:0.24em;text-transform:uppercase;
  color:var(--paper-dim);
}
.locale-picker-btn{
  display:flex;align-items:center;gap:14px;
  padding:14px 18px;border-radius:12px;
  background:rgba(255,255,255,0.04);
  border:1px solid var(--hairline-strong);
  cursor:pointer;text-align:left;width:100%;
  font-family:var(--font-body);color:var(--paper);
  transition:border-color .2s, background .2s, box-shadow .2s, transform .2s;
}
.locale-picker-btn:hover{
  border-color:var(--cyan);
  background:rgba(34,211,238,0.10);
}
.locale-picker-btn[aria-expanded="true"]{
  border-color:var(--cyan);
  background:rgba(34,211,238,0.10);
  box-shadow:0 0 0 4px rgba(34,211,238,0.10);
}
.locale-picker-flag{font-size:22px;line-height:1;flex-shrink:0}
.locale-picker-text{flex:1;font-weight:700;font-size:15px;letter-spacing:0.04em}
.locale-picker-chev{opacity:0.7;font-size:11px;flex-shrink:0;transition:transform .2s}
.locale-picker-btn[aria-expanded="true"] .locale-picker-chev{transform:rotate(180deg)}

.locale-picker-panel{
  position:absolute;top:calc(100% + 6px);left:0;right:0;
  background:rgba(2,15,50,0.97);backdrop-filter:blur(14px);
  border:1px solid var(--hairline-strong);border-radius:12px;
  padding:6px;display:none;z-index:30;
  max-height:340px;overflow-y:auto;
  box-shadow:0 20px 60px rgba(0,0,0,0.6), 0 0 0 1px rgba(34,211,238,0.18);
}
.locale-picker-panel.open{display:block}
.locale-picker-item{
  display:flex;align-items:center;gap:10px;
  padding:10px 12px;border-radius:8px;cursor:pointer;
  font-family:var(--font-body);font-size:14px;color:var(--paper);font-weight:500;letter-spacing:0.02em;
  transition:background .15s;
}
.locale-picker-item:hover{background:rgba(34,211,238,0.12)}
.locale-picker-item.active{background:rgba(34,211,238,0.20);outline:1px solid rgba(34,211,238,0.45)}
.locale-picker-item .f{font-size:18px;line-height:1;flex-shrink:0}
.locale-picker-item .meta{font-size:11px;color:var(--paper-dim);margin-left:auto;letter-spacing:0.04em}

/* ---------- Books grid ---------- */
.books{padding:30px 0 40px}
.books-head{display:flex;align-items:baseline;justify-content:space-between;flex-wrap:wrap;gap:14px;margin-bottom:28px;padding-bottom:14px;border-bottom:1px solid var(--hairline)}
.books-head h2{font-family:var(--font-display);font-weight:700;font-size:24px;letter-spacing:0.02em;text-transform:uppercase}
.books-head .count{font-family:var(--font-body);font-size:12px;letter-spacing:0.22em;text-transform:uppercase;color:var(--paper-dim)}

.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px}
@media (max-width:980px){.grid{grid-template-columns:1fr;gap:48px;max-width:420px;margin:0 auto}}

.book{
  position:relative;border-radius:18px;overflow:hidden;
  background:linear-gradient(180deg, rgba(255,255,255,0.025), rgba(255,255,255,0.01));
  border:1px solid var(--hairline);
  display:flex;flex-direction:column;
  transition:transform .35s cubic-bezier(0.2,0.8,0.2,1),border-color .35s,box-shadow .35s;
}
.book::before{
  content:"";position:absolute;inset:-1px;border-radius:inherit;padding:1px;
  background:linear-gradient(135deg, var(--a, var(--cyan)), var(--b, var(--purple)));
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;
  opacity:0;transition:opacity .35s;pointer-events:none;
}
.grid .book{cursor:pointer}
.grid .book:hover{transform:translateY(-6px)}
.grid .book:hover::before{opacity:1}
.grid .book:hover{box-shadow:0 30px 80px -20px rgba(0,0,0,0.65),0 0 0 1px var(--a) inset}
/* Subtle "click to view" hint badge in the corner of catalog cards */
.grid .book::after{
  content:"VIEW →";position:absolute;top:14px;right:14px;
  font-family:var(--font-body);font-weight:700;font-size:9px;letter-spacing:0.22em;color:var(--paper-dim);
  background:rgba(0,0,0,0.4);border:1px solid var(--hairline-strong);
  padding:5px 8px;border-radius:6px;
  opacity:0;transform:translateY(-4px);transition:opacity .25s,transform .25s,color .25s,border-color .25s;
  pointer-events:none;z-index:5;
}
.grid .book:hover::after{opacity:1;transform:translateY(0);color:var(--cyan);border-color:var(--cyan)}

.meta{padding:8px 24px 26px;display:flex;flex-direction:column;gap:12px;flex:1}
.book-sub{font-family:var(--font-body);font-size:11px;letter-spacing:0.22em;text-transform:uppercase;color:var(--paper-dim)}
.book-title{font-family:var(--font-display);font-weight:700;font-size:28px;line-height:1.1;letter-spacing:0.01em}
.book-blurb{font-size:15px;color:var(--paper-dim);flex:1}
.book-langs{
  font-family:var(--font-body);font-size:11px;letter-spacing:0.16em;text-transform:uppercase;color:var(--paper-dim);
  padding-top:10px;border-top:1px dashed var(--hairline);margin-top:4px;
}
.book-langs b{color:var(--paper);font-weight:600}

.buy{
  position:relative;display:inline-flex;align-items:center;justify-content:center;gap:10px;
  margin-top:14px;padding:14px 18px;border-radius:10px;
  font-family:var(--font-body);font-size:12px;font-weight:700;letter-spacing:0.22em;text-transform:uppercase;color:#fff;
  background:linear-gradient(90deg, var(--a), var(--b));
  border:1px solid transparent;cursor:pointer;
  transition:transform .2s ease,box-shadow .2s ease,filter .2s ease;
  overflow:hidden;
}
.buy:hover{transform:translateY(-1px);box-shadow:0 14px 36px -10px color-mix(in srgb, var(--a) 55%, transparent),0 0 0 1px rgba(255,255,255,0.18)}
.buy:active{transform:translateY(0)}
.buy small{font-weight:500;letter-spacing:0.16em;opacity:0.85;font-size:10px}
.buy svg{width:14px;height:14px}

/* ---------- 3D Books ---------- */
.book3d-stage{
  --book-w:200px;
  --book-h:300px;
  --book-depth:25px;
  --spread-w:425px;
  --book-image:none;
  perspective:2000px;
  display:flex;align-items:center;justify-content:center;
  height:340px;position:relative;
  margin:14px 0 6px;
  /* Suppress browser default touch behaviors (scroll, pinch-zoom) inside
     the whole book stage — not just on .book3d — so a 2nd finger that
     lands in the stage's padding area still doesn't trigger page zoom. */
  touch-action:none;
}
.book3d-stage::after{
  content:"";position:absolute;left:50%;bottom:18px;transform:translateX(-50%);
  width:calc(var(--book-w) + 60px);height:18px;border-radius:50%;
  background:radial-gradient(closest-side, rgba(0,0,0,0.55), transparent 70%);
  filter:blur(6px);z-index:0;
}
.book3d{
  position:relative;
  width:var(--book-w);height:var(--book-h);
  transform-style:preserve-3d;
  cursor:grab;z-index:1;
  transform:rotateY(-15deg) rotateX(6deg);
  touch-action:none;
}
.book3d.dragging{cursor:grabbing}
.book3d > div{position:absolute;background-color:#0a1e3a;background-repeat:no-repeat}
.book3d .front,.book3d .back,.book3d .spine{
  background-image:var(--book-image);
  background-size:var(--spread-w) var(--book-h);
}
.book3d .front{
  width:var(--book-w);height:var(--book-h);top:0;left:0;
  background-position:right center;
  transform:translateZ(calc(var(--book-depth) / 2));
  box-shadow:inset 0 0 0 1px rgba(255,255,255,0.06);
}
.book3d .back{
  width:var(--book-w);height:var(--book-h);top:0;left:0;
  background-position:left center;
  transform:translateZ(calc(var(--book-depth) / -2)) rotateY(180deg);
}
.book3d .spine{
  width:var(--book-depth);height:var(--book-h);top:0;left:0;
  background-position:center center;
  transform:rotateY(-90deg) translateZ(calc(var(--book-depth) / 2));
}
/* Paper edges — stripes run perpendicular to stack direction.
   .pages: pages stack horizontally across book-thickness → vertical stripes (90deg)
   .top/.bottom: pages stack vertically across book-thickness → horizontal stripes (180deg)
   Low-contrast overlay on a soft cream-tan base so it reads as paper, not a barcode. */
.book3d .pages{
  width:var(--book-depth);height:var(--book-h);top:0;left:0;
  background:
    repeating-linear-gradient(90deg, rgba(120,85,30,0.18) 0 1px, transparent 1px 3px),
    linear-gradient(90deg, #d9c191 0%, #efddb3 30%, #f3e3bb 50%, #efddb3 70%, #d9c191 100%);
  transform:rotateY(90deg) translateZ(calc(var(--book-w) - var(--book-depth) / 2));
}
.book3d .top,.book3d .bottom{
  width:var(--book-w);height:var(--book-depth);left:0;
  background:
    repeating-linear-gradient(180deg, rgba(120,85,30,0.18) 0 1px, transparent 1px 3px),
    linear-gradient(180deg, #d9c191 0%, #efddb3 30%, #f3e3bb 50%, #efddb3 70%, #d9c191 100%);
}
.book3d .top   {top:0;                                       transform:rotateX(90deg)  translateZ(calc(var(--book-depth) / 2))}
.book3d .bottom{top:calc(var(--book-h) - var(--book-depth)); transform:rotateX(-90deg) translateZ(calc(var(--book-depth) / 2))}

.book[data-id="eyeth"] .book3d-stage{--book-depth:58px;--spread-w:458px;--book-image:url("covers/eyeth-wrap.jpg")}
.book[data-id="mmmak"] .book3d-stage{--book-depth:25px;--spread-w:425px;--book-image:url("covers/mmmak-en-wrap.jpg")}
.book[data-id="mmtf"]  .book3d-stage{--book-depth:25px;--spread-w:425px;--book-image:url("covers/mmtf-en-wrap.jpg")}

/* MMTF and MMMAK use white paper; Eyeth keeps the cream default above. */
.book[data-id="mmtf"]  .book3d .pages,
.book[data-id="mmmak"] .book3d .pages{
  background:
    repeating-linear-gradient(90deg, rgba(40,30,15,0.10) 0 1px, transparent 1px 3px),
    linear-gradient(90deg, #d8d8d8 0%, #f4f4f4 25%, #ffffff 50%, #f4f4f4 75%, #d8d8d8 100%);
}
.book[data-id="mmtf"]  .book3d .top,
.book[data-id="mmtf"]  .book3d .bottom,
.book[data-id="mmmak"] .book3d .top,
.book[data-id="mmmak"] .book3d .bottom{
  background:
    repeating-linear-gradient(180deg, rgba(40,30,15,0.10) 0 1px, transparent 1px 3px),
    linear-gradient(180deg, #d8d8d8 0%, #f4f4f4 25%, #ffffff 50%, #f4f4f4 75%, #d8d8d8 100%);
}

.book3d.no-image .front,.book3d.no-image .back,.book3d.no-image .spine{
  background-image:none !important;
  background:linear-gradient(135deg, var(--a), var(--b));
}
.book3d .fallback-title{display:none}
.book3d.no-image .fallback-title{
  display:flex;align-items:center;justify-content:center;
  position:absolute;inset:0;padding:18px;
  font-family:var(--font-display);font-weight:700;font-size:22px;line-height:1.05;
  color:#fff;text-align:center;text-transform:uppercase;
  text-shadow:0 2px 18px rgba(0,0,0,0.4);
}
.book[data-id="eyeth"] .book3d.no-image .fallback-title{
  font-family:var(--font-deaf);font-weight:400;text-transform:none;
  font-size:48px;letter-spacing:0.04em;
}

/* ---------- Featured Artists callout (index page link to artists.html) ---------- */
.artists-callout{padding:34px 0 6px}
.artists-callout-card{
  display:grid;grid-template-columns:auto 1fr;gap:22px;
  padding:18px 22px;border-radius:18px;
  background:linear-gradient(180deg, rgba(255,255,255,0.025), rgba(255,255,255,0.01));
  border:1px solid var(--hairline);
  align-items:center;
  text-decoration:none;color:var(--paper);
  transition:transform .3s ease, border-color .3s ease, box-shadow .3s ease;
}
.artists-callout-card:hover{
  transform:translateY(-3px);border-color:var(--cyan);
  box-shadow:0 20px 50px -20px rgba(0,0,0,0.6), 0 0 0 1px rgba(34,211,238,0.25) inset;
}
@media (max-width:760px){.artists-callout-card{grid-template-columns:1fr;gap:14px;padding:16px}}
.artists-callout-strip{display:flex;gap:-12px;flex-shrink:0;align-items:center}
.artists-callout-strip img{
  width:72px;height:72px;border-radius:50%;
  object-fit:cover;
  border:3px solid var(--night-1);
  margin-left:-18px;
  box-shadow:0 4px 12px rgba(0,0,0,0.4);
  transition:transform .25s ease;
}
.artists-callout-strip img:first-child{margin-left:0}
.artists-callout-card:hover .artists-callout-strip img{transform:scale(1.05)}
.artists-callout-meta{display:flex;flex-direction:column;gap:8px}
.artists-callout-meta .kicker{margin-bottom:0;align-self:flex-start}
.artists-callout-meta h3{
  font-family:var(--font-display);font-weight:700;
  font-size:clamp(20px,2.4vw,28px);line-height:1.15;letter-spacing:0.01em;
  text-transform:uppercase;
}
.artists-callout-meta p{
  font-family:var(--font-body);font-size:14px;line-height:1.5;
  color:var(--paper-dim);margin:0;
}
.artists-callout-meta p strong{color:var(--paper);font-weight:700}
.artists-callout-meta p em{color:var(--paper);font-style:italic}
.artists-callout-cta{
  align-self:flex-start;margin-top:4px;
  font-family:var(--font-body);font-weight:700;font-size:12px;
  letter-spacing:0.22em;text-transform:uppercase;color:var(--cyan);
  padding-bottom:2px;border-bottom:1px dashed var(--cyan);
}
.artists-callout-card:hover .artists-callout-cta{color:var(--lime);border-color:var(--lime)}

/* ---------- KDP distribution / availability disclosure ---------- */
.kdp-note{padding:40px 0 0}
.kdp-note-card{
  border-radius:14px;
  background:rgba(255,255,255,0.025);
  border:1px solid var(--hairline);
  padding:22px 28px;
}
.kdp-note-card h3{
  font-family:var(--font-body);font-weight:700;
  font-size:11px;letter-spacing:0.22em;text-transform:uppercase;
  color:var(--paper-dim);margin-bottom:12px;
}
.kdp-note-card p{
  font-family:var(--font-body);font-size:13px;line-height:1.65;
  color:var(--paper-dim);margin-bottom:10px;
}
.kdp-note-card p strong{color:var(--paper);font-weight:700}
.kdp-note-card p:last-child{margin-bottom:0}
.kdp-markets{
  list-style:none;padding:0;margin:12px 0;
  /* auto-fit: pack as many columns as fit, each at least 290px wide.
     This avoids hardcoded breakpoints that let cells overflow at awkward
     widths between 760–880px before wrapping. */
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(290px, 1fr));
  gap:6px 18px;
}
.kdp-markets li{
  /* Mini table — fixed column widths so every row aligns the same:
       flag (24px) · country name (130px) · URL pill (auto, hugs the name) */
  display:grid;
  grid-template-columns:24px 130px auto;
  align-items:center;gap:10px;
  justify-content:start;
  font-family:var(--font-body);font-size:13px;line-height:1.4;
  color:var(--paper);padding:4px 0;
}
.kdp-markets .kdp-flag{font-size:16px;line-height:1;flex-shrink:0}
.kdp-markets .kdp-url{
  font-family:ui-monospace,SFMono-Regular,Menlo,monospace;
  font-size:11px;color:var(--paper-dim);
  background:rgba(34,211,238,0.08);
  padding:2px 8px;border-radius:6px;
  letter-spacing:0.02em;
}
.kdp-markets .kdp-sales{
  font-family:var(--font-body);font-weight:700;
  font-size:11px;color:var(--paper);
  background:rgba(163,230,53,0.12);
  border:1px solid rgba(163,230,53,0.25);
  padding:2px 8px;border-radius:6px;
  min-width:32px;text-align:center;
  letter-spacing:0.02em;
}

/* ---------- Book detail page ---------- */
.detail{padding:60px 0 120px}
.back-link{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--font-body);font-size:11px;font-weight:700;
  letter-spacing:0.22em;text-transform:uppercase;
  color:var(--paper-dim);margin-bottom:36px;
  transition:color .2s;
}
.back-link:hover{color:var(--cyan)}
.detail-grid{
  display:grid;
  grid-template-columns:minmax(320px, 380px) 1fr;
  gap:60px;align-items:start;
}
@media (max-width:900px){.detail-grid{grid-template-columns:1fr;gap:32px}}

.detail-book .book3d-stage{
  --book-w:280px;--book-h:420px;
  height:480px;margin:0 auto;
}
.detail-book .book[data-id="eyeth"] .book3d-stage{--book-depth:82px;--spread-w:642px}
.detail-book .book[data-id="mmmak"] .book3d-stage,
.detail-book .book[data-id="mmtf"]  .book3d-stage{--book-depth:35px;--spread-w:595px}

/* Match the home-page card's inner breathing room — .detail-copy doubles as a .book card */
.detail-copy{
  padding:30px 36px 34px;
}
@media (max-width:600px){.detail-copy{padding:24px 22px 26px}}
.detail-copy .kicker{margin-bottom:6px}

.detail-copy h1{
  font-family:var(--font-display);font-weight:700;
  font-size:clamp(40px,5.5vw,72px);line-height:1.0;
  text-transform:uppercase;letter-spacing:0.005em;
  margin:14px 0 12px;
  text-shadow:0 4px 40px rgba(34,211,238,0.18);
}
.detail-copy h1 em{font-style:normal;background:linear-gradient(90deg,var(--a),var(--b));-webkit-background-clip:text;background-clip:text;color:transparent;font-weight:700}
.detail-copy .lead{
  font-size:18px;color:var(--paper);font-style:italic;
  margin-bottom:20px;font-family:var(--font-body);
}
.detail-copy p{margin-bottom:14px;color:var(--paper-dim);font-size:15px;line-height:1.6}
.detail-copy p strong{color:var(--paper);font-weight:700}
.detail-meta{
  margin:24px 0;padding:18px 22px;
  background:rgba(255,255,255,0.03);
  border:1px solid var(--hairline);border-radius:12px;
  display:grid;gap:8px;
}
.detail-meta div{font-size:13px;color:var(--paper-dim);font-family:var(--font-body);letter-spacing:0.04em}
.detail-meta b{color:var(--paper);font-weight:700;text-transform:uppercase;letter-spacing:0.12em;font-size:11px;margin-right:6px}
.detail-copy .buy{font-size:13px;padding:16px 28px;margin-top:14px;align-self:flex-start}
.detail-copy .locale-now{margin-top:18px;font-size:11px;justify-content:flex-start}

/* ---------- Featured Artists page ---------- */
.artists{padding:48px 0 80px}
.artists-head{text-align:center;margin:24px auto 48px;max-width:780px}
.artists-head h1{
  font-family:var(--font-display);font-weight:700;
  font-size:clamp(40px,5.5vw,72px);line-height:0.95;
  text-transform:uppercase;letter-spacing:0.01em;
  margin:14px 0 16px;
  text-shadow:0 4px 40px rgba(34,211,238,0.20);
}
.artists-head .lede{
  font-size:17px;color:var(--paper-dim);line-height:1.6;
  font-family:var(--font-body);
}
.artists-head .lede em{color:var(--paper);font-style:italic}

/* Star Sign School hero card */
.artist-hero{
  display:grid;grid-template-columns:1fr 1fr;gap:0;
  border-radius:18px;overflow:hidden;
  background:linear-gradient(180deg, rgba(255,255,255,0.04), rgba(255,255,255,0.01));
  border:1px solid var(--hairline);
  margin-bottom:60px;
  position:relative;
}
.artist-hero::before{
  content:"";position:absolute;inset:-1px;border-radius:inherit;padding:1px;
  background:linear-gradient(135deg, var(--cyan), var(--teal), var(--lime));
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;
  opacity:0.5;pointer-events:none;
}
@media (max-width:880px){.artist-hero{grid-template-columns:1fr}}
.artist-hero-art{position:relative;min-height:380px;overflow:hidden}
.artist-hero-art img{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;display:block;
}
.artist-hero-meta{padding:36px 36px 38px;display:flex;flex-direction:column;gap:14px}
@media (max-width:600px){.artist-hero-meta{padding:24px}}
.artist-tag{
  font-family:var(--font-body);font-weight:700;font-size:10px;
  letter-spacing:0.32em;text-transform:uppercase;color:var(--cyan);
}
.artist-hero-meta h2{
  font-family:var(--font-display);font-weight:700;
  font-size:clamp(32px,4vw,52px);line-height:1.0;letter-spacing:0.01em;
  text-transform:uppercase;
  background:linear-gradient(90deg,var(--cyan),var(--teal),var(--lime));
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.artist-role{
  font-family:var(--font-body);font-size:16px;color:var(--paper);
  font-style:italic;line-height:1.5;
}
.artist-hero-meta p{font-family:var(--font-body);font-size:14px;line-height:1.65;color:var(--paper-dim);margin:0}
.artist-hero-meta p strong{color:var(--paper);font-weight:700}
.artist-hero-meta p em{color:var(--paper);font-style:italic}
.artist-meta-row{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}
.artist-pill{
  display:inline-flex;padding:6px 12px;border-radius:999px;
  background:rgba(34,211,238,0.10);border:1px solid rgba(34,211,238,0.30);
  font-family:var(--font-body);font-size:11px;font-weight:700;
  letter-spacing:0.16em;text-transform:uppercase;color:var(--paper);
}

/* Section heading for individual contributors */
.artists-section-head{
  font-family:var(--font-display);font-weight:700;
  font-size:24px;letter-spacing:0.02em;text-transform:uppercase;
  margin:8px 0 24px;padding-bottom:14px;
  border-bottom:1px solid var(--hairline);
}

/* Individual artist grid */
.artist-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
@media (max-width:760px){.artist-grid{grid-template-columns:1fr}}
.artist-card{
  display:grid;grid-template-columns:200px 1fr;gap:0;
  border-radius:14px;overflow:hidden;
  background:linear-gradient(180deg, rgba(255,255,255,0.025), rgba(255,255,255,0.01));
  border:1px solid var(--hairline);
  transition:transform .3s ease, border-color .3s ease, box-shadow .3s ease;
}
.artist-card:hover{transform:translateY(-3px);border-color:var(--cyan);box-shadow:0 18px 40px -16px rgba(0,0,0,0.5)}
@media (max-width:600px){.artist-card{grid-template-columns:1fr}}
.artist-card-art{position:relative;min-height:220px;overflow:hidden}
.artist-card-art img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
.artist-card-meta{padding:18px 20px;display:flex;flex-direction:column;gap:6px;font-family:var(--font-body)}
.artist-card-meta h3{
  font-family:var(--font-display);font-weight:700;
  font-size:20px;line-height:1.1;letter-spacing:0.01em;
  color:var(--paper);margin-bottom:2px;
}
.artist-loc{font-size:13px;color:var(--paper);font-weight:600;letter-spacing:0.04em}
.artist-medium{font-size:11px;color:var(--paper-dim);letter-spacing:0.18em;text-transform:uppercase;font-weight:700}
.artist-pieces{font-size:12px;color:var(--cyan);font-weight:700;letter-spacing:0.04em}
.artist-titles{font-size:12px;color:var(--paper-dim);line-height:1.5;margin-top:4px}
.artist-link{
  display:inline-flex;align-items:center;align-self:flex-start;
  margin-top:8px;padding:5px 12px;border-radius:999px;
  font-family:ui-monospace,SFMono-Regular,Menlo,monospace;
  font-size:11px;letter-spacing:0.04em;
  background:rgba(34,211,238,0.10);border:1px solid var(--hairline-strong);
  color:var(--paper);transition:border-color .2s,background .2s,color .2s;
}
.artist-link:hover{border-color:var(--cyan);background:rgba(34,211,238,0.20);color:var(--cyan)}

.artists-footnote{
  margin:48px auto 0;max-width:680px;text-align:center;
  font-family:var(--font-body);font-size:13px;color:var(--paper-dim);font-style:italic;
}

/* Subsection heading inside the artists page */
.artists-subsection-head{
  font-family:var(--font-body);font-weight:700;
  font-size:11px;letter-spacing:0.24em;text-transform:uppercase;
  color:var(--paper-dim);
  margin:32px 0 18px;
}

/* Smaller grid for the 6 student cards (mix of portrait and text-only) */
.artist-grid-students{grid-template-columns:repeat(3,1fr)}
@media (max-width:900px){.artist-grid-students{grid-template-columns:repeat(2,1fr)}}
@media (max-width:600px){.artist-grid-students{grid-template-columns:1fr}}

.artist-card-mini{
  padding:18px 20px;border-radius:12px;
  background:linear-gradient(180deg, rgba(255,255,255,0.025), rgba(255,255,255,0.01));
  border:1px solid var(--hairline);
  display:flex;flex-direction:column;gap:6px;
  font-family:var(--font-body);
  transition:transform .25s ease, border-color .25s ease;
  overflow:hidden;
}
.artist-card-mini:hover{transform:translateY(-2px);border-color:var(--cyan)}
.artist-card-mini h3{
  font-family:var(--font-display);font-weight:700;
  font-size:18px;line-height:1.15;letter-spacing:0.01em;
  color:var(--paper);
}

/* Portrait at the top of a mini card */
.artist-card-mini.has-portrait{padding-top:0}
.artist-card-mini .artist-portrait{
  margin:-18px -20px 12px;
  aspect-ratio:4/3;
  overflow:hidden;
  background:#0a1430;
  border-bottom:1px solid var(--hairline);
}
.artist-card-mini .artist-portrait img{
  width:100%;height:100%;object-fit:cover;display:block;
  transition:transform .6s ease;
}
.artist-card-mini.has-portrait:hover .artist-portrait img{transform:scale(1.04)}

.artist-quote{
  font-family:var(--font-body);font-size:13px;line-height:1.55;
  color:var(--paper);font-style:italic;
  border-left:2px solid var(--cyan);
  padding-left:10px;margin-top:6px;
}

/* Founder card — wider, with portrait */
.founder-card{
  padding:24px 28px;border-radius:14px;
  background:linear-gradient(180deg, rgba(34,211,238,0.04), rgba(20,184,166,0.02));
  border:1px solid var(--hairline-strong);
  display:grid;grid-template-columns:220px 1fr;gap:28px;align-items:start;
}
@media (max-width:700px){
  .founder-card{grid-template-columns:1fr;gap:18px}
}
.founder-portrait{
  width:100%;aspect-ratio:3/4;
  border-radius:10px;overflow:hidden;
  background:#0a1430;
  border:1px solid var(--hairline);
  box-shadow:0 12px 36px -16px rgba(0,0,0,0.65);
}
.founder-portrait img{width:100%;height:100%;object-fit:cover;display:block}
@media (max-width:700px){
  .founder-portrait{aspect-ratio:4/3;max-width:340px;margin:0 auto}
}
.founder-meta h3{
  font-family:var(--font-display);font-weight:700;
  font-size:24px;line-height:1.1;letter-spacing:0.01em;
  text-transform:uppercase;
  background:linear-gradient(90deg,var(--cyan),var(--teal));
  -webkit-background-clip:text;background-clip:text;color:transparent;
  margin:4px 0 6px;
}
.founder-meta p{font-family:var(--font-body);font-size:14px;line-height:1.6;color:var(--paper-dim);margin:0}
.founder-meta p strong{color:var(--paper);font-weight:700}

/* Placeholder card-art (initials when no artwork uploaded yet) */
.artist-card-art-placeholder{
  background:linear-gradient(135deg, var(--cyan), var(--teal), var(--lime));
  display:flex;align-items:center;justify-content:center;
  min-height:220px;
}
.artist-initials{
  font-family:var(--font-display);font-weight:700;
  font-size:84px;line-height:1;letter-spacing:0.02em;
  color:rgba(255,255,255,0.95);
  text-shadow:0 4px 20px rgba(0,0,0,0.3);
}

/* ---------- Footer ---------- */
footer{margin-top:120px;padding:50px 0 70px;border-top:1px solid var(--hairline);color:var(--paper-dim);font-family:var(--font-body);font-size:13px}
.foot{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:18px;letter-spacing:0.06em}
.foot-socials{display:flex;gap:14px;flex-wrap:wrap}
.foot-socials a{
  display:inline-flex;align-items:center;gap:8px;
  color:var(--paper-dim);font-size:11px;letter-spacing:0.22em;text-transform:uppercase;
  padding:6px 12px 6px 6px;border-radius:999px;
  background:rgba(255,255,255,0.03);border:1px solid var(--hairline-strong);
  transform-origin:center;
  transition:color .2s,border-color .2s,background .2s,
             transform .25s cubic-bezier(0.34, 1.56, 0.64, 1),
             box-shadow .25s ease;
}
.foot-socials a:hover{
  color:var(--paper);border-color:var(--cyan);background:rgba(34,211,238,0.10);
  transform:scale(1.12);
  box-shadow:0 6px 20px -6px rgba(34,211,238,0.35), 0 0 0 4px rgba(34,211,238,0.08);
}
.foot-socials a img{width:20px;height:20px;object-fit:contain;display:block}
/* Gmail icon is a transparent SVG with a wide envelope shape — render it on a
   white rounded square (a circle would crop the envelope) and add inner
   padding so the colored envelope has a clean margin inside. Same 20×20 outer
   size as the other social icons. */
.foot-socials a img[src*="gmail"]{
  border-radius:5px;
  background:#fff;
  padding:3px;
  box-sizing:border-box;
  box-shadow:0 0 0 1px rgba(255,255,255,0.15);
}
.foot-socials a svg{width:20px;height:20px;flex-shrink:0;color:var(--paper-dim);display:block}
.foot-socials a:hover svg{color:var(--cyan)}
.foot-socials a .gx{
  font-family:var(--font-deaf);font-weight:400;
  font-size:24px;line-height:1;letter-spacing:0.06em;
  color:var(--paper);text-transform:none;
}
.foot-socials a .gx-name{
  font-family:var(--font-body);font-weight:700;
  font-size:11px;letter-spacing:0.22em;text-transform:uppercase;
  color:inherit;
}
.foot-socials a:hover .gx{color:var(--cyan)}
.copy{margin-top:18px;color:#4a527a;font-size:11px;letter-spacing:0.1em}

/* book accent colors */
.book[data-id="eyeth"]{--a:var(--eyeth-a);--b:var(--eyeth-b)}
.book[data-id="mmmak"]{--a:var(--mmmak-a);--b:var(--mmmak-b)}
.book[data-id="mmtf"] {--a:var(--mmtf-a); --b:var(--mmtf-b)}

/* ============================================================
   SITE NAVIGATION (index.html only) — comprehensive page index
   ============================================================ */
.sitemap-section{padding:60px 0 40px;margin-top:60px;border-top:1px solid var(--hairline)}
.sitemap-head{text-align:center;margin-bottom:40px}
.sitemap-head .kicker{
  display:inline-flex;align-items:center;gap:8px;
  padding:5px 14px;border-radius:999px;
  background:rgba(34,211,238,0.10);border:1px solid var(--hairline-strong);
  font-family:var(--font-body);font-size:11px;letter-spacing:0.22em;
  color:var(--paper-dim);text-transform:uppercase;font-weight:700;
}
.sitemap-head .kicker .pulse{
  width:8px;height:8px;border-radius:50%;background:var(--cyan);
  box-shadow:0 0 8px var(--cyan);animation:pulse 1.8s ease-in-out infinite;
}
.sitemap-head h2{
  font-family:var(--font-display);font-weight:700;font-size:36px;
  letter-spacing:0.02em;text-transform:uppercase;margin:14px 0 6px;
  background:linear-gradient(90deg,var(--cyan),var(--teal),var(--lime));
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.sitemap-head .lede{font-family:var(--font-body);font-size:13px;color:var(--paper-dim)}

.sitemap-group{margin:32px 0}
.sitemap-group h3{
  font-family:var(--font-body);font-weight:700;font-size:11px;
  letter-spacing:0.28em;text-transform:uppercase;color:var(--paper-dim);
  margin:0 0 18px;padding-bottom:8px;border-bottom:1px dashed var(--hairline);
}
.sm-subhead{
  font-family:var(--font-body);font-weight:700;font-size:10px;
  letter-spacing:0.24em;text-transform:uppercase;color:var(--paper-dim);
  margin:28px 0 12px;opacity:0.85;
}

.sitemap-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:14px;
}
.sitemap-grid-compact{
  grid-template-columns:repeat(auto-fill, minmax(220px, 1fr));gap:10px;
}
@media (max-width:780px){
  .sitemap-grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:480px){
  .sitemap-grid{grid-template-columns:1fr}
}

.sm-card{
  display:flex;flex-direction:column;gap:6px;
  padding:16px 18px;border-radius:12px;
  background:linear-gradient(180deg, rgba(255,255,255,0.025), rgba(255,255,255,0.01));
  border:1px solid var(--hairline);
  text-decoration:none;color:var(--paper);
  transition:transform .25s cubic-bezier(0.2,0.8,0.2,1), border-color .25s, background .25s, box-shadow .25s;
}
.sm-card:hover{
  transform:translateY(-2px);
  border-color:var(--cyan);
  background:linear-gradient(180deg, rgba(34,211,238,0.06), rgba(34,211,238,0.02));
  box-shadow:0 10px 28px -12px rgba(34,211,238,0.35);
}
.sm-card .sm-label{
  font-family:var(--font-display);font-weight:700;font-size:14px;
  letter-spacing:0.01em;line-height:1.2;color:var(--paper);
}
.sm-card .sm-desc{
  font-family:var(--font-body);font-size:11px;color:var(--paper-dim);
  letter-spacing:0.04em;line-height:1.4;
}

/* Per-book accent border on main pages */
.sm-eyeth:hover{border-color:#22d3ee;box-shadow:0 10px 28px -12px rgba(34,211,238,0.4)}
.sm-mmmak:hover{border-color:#84cc16;box-shadow:0 10px 28px -12px rgba(132,204,22,0.4)}
.sm-mmtf:hover{border-color:#f472b6;box-shadow:0 10px 28px -12px rgba(244,114,182,0.4)}
.sm-artists:hover{border-color:var(--lime);box-shadow:0 10px 28px -12px rgba(190,242,100,0.4)}
.sm-select:hover{border-color:var(--purple,#a78bfa);box-shadow:0 10px 28px -12px rgba(167,139,250,0.4)}

/* Compact "internal" cards — smaller, single-line */
.sm-internal{
  padding:10px 14px;gap:0;
  background:rgba(255,255,255,0.02);
}
.sm-internal .sm-label{font-size:12px;font-weight:600}
.sm-internal:hover{
  background:linear-gradient(180deg, rgba(134,163,214,0.08), rgba(134,163,214,0.03));
  border-color:var(--paper-dim);
}
