/* ============================================================
   KOREAMAT.NO — delt designsystem
   Palett: Taegeuk (hanji-hvit · dancheong-rød · indigoblå)
   ============================================================ */

:root{
  /* Taegeuk-palett */
  --bg:#f4efe5;
  --bg-2:#ece5d7;
  --paper:#fbf8f1;
  --ink:#201b14;
  --ink-soft:#6e6556;
  --accent:oklch(0.53 0.18 27);        /* dancheong-rød */
  --accent-2:oklch(0.46 0.11 256);     /* indigoblå */
  --accent-soft:oklch(0.91 0.04 70);   /* varm sand */
  --brand-red:#a82a48;                 /* logo-rød */
  --line:rgba(32,27,20,0.13);
  --line-strong:rgba(32,27,20,0.24);

  --display:'Space Grotesk',system-ui,sans-serif;
  --sans:'Hanken Grotesk',system-ui,sans-serif;
  --serif:'Spectral',Georgia,serif;

  --maxw:1200px;
  --pad:48px;
  --radius:5px;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--sans);
  background:var(--bg);
  color:var(--ink);
  -webkit-font-smoothing:antialiased;
  line-height:1.55;
  overflow-x:hidden;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
button{font:inherit;cursor:pointer}
::selection{background:var(--accent);color:var(--paper)}

h1,h2,h3,h4{font-family:var(--display);font-weight:500;line-height:1.05;letter-spacing:-0.03em}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--pad)}
.wrap-narrow{max-width:820px;margin:0 auto;padding:0 var(--pad)}

/* ---------- labels / eyebrows ---------- */
.label{font-family:var(--display);font-size:11.5px;font-weight:500;letter-spacing:0.26em;text-transform:uppercase;color:var(--ink-soft)}
.label b{color:var(--accent);font-weight:500}
.label b.kr{color:var(--accent-2)}
.han{font-family:var(--sans)}
.kr{color:var(--accent-2)}

/* ---------- placeholders ---------- */
.ph{position:relative;overflow:hidden;background:
    repeating-linear-gradient(90deg,var(--bg-2),var(--bg-2) 13px,#e2dccb 13px,#e2dccb 14px)}
.ph::after{content:attr(data-label);position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
    font-family:ui-monospace,'SF Mono',Menlo,monospace;font-size:10px;letter-spacing:0.06em;color:var(--ink-soft);
    background:var(--paper);padding:5px 9px;white-space:nowrap;border-radius:2px}
.ph.dark{background:repeating-linear-gradient(90deg,#2a251d,#2a251d 13px,#332d23 13px,#332d23 14px)}
.ph.dark::after{background:#201b14;color:#cfc6b4}
.ph.has-photo{background:none}
.ph.has-photo::after{display:none}
.ph.has-photo img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:9px;font-family:var(--display);font-size:14px;font-weight:500;
     padding:15px 28px;border-radius:var(--radius);background:var(--ink);color:var(--bg);border:1px solid var(--ink);
     transition:opacity .2s,transform .2s;white-space:nowrap}
.btn:hover{opacity:.88}
.btn:active{transform:translateY(1px)}
.btn-accent{background:var(--accent);border-color:var(--accent);color:var(--paper)}
.btn-out{background:none;color:var(--ink);border:1px solid var(--line-strong)}
.btn-out:hover{border-color:var(--ink);opacity:1}
.btn-sm{padding:11px 20px;font-size:13px}

.link-more{font-family:var(--display);font-size:13px;font-weight:500;color:var(--accent);
           display:inline-flex;gap:7px;align-items:center;white-space:nowrap;transition:gap .2s}
.link-more:hover{gap:12px}

/* ---------- header / nav ---------- */
header.site{position:sticky;top:0;z-index:100;background:color-mix(in srgb,var(--bg) 85%,transparent);
            backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:76px;gap:24px}
.brand{font-family:var(--serif);font-size:25px;font-weight:600;letter-spacing:-0.005em;display:flex;align-items:center;gap:11px;white-space:nowrap;line-height:1}
.brand .brand-mark{width:42px;height:42px;object-fit:contain;flex:none}
.brand .lk-word{color:var(--ink)}
.brand .lk-accent{color:var(--ink)}
.brand .lk-tld{color:var(--ink);font-weight:500}

/* tagline som del av header-logoen */
header.site .brand{align-items:center}
.brand-lock{display:flex;flex-direction:column;gap:5px}
.brand-tag{font-family:var(--display);font-size:10.5px;font-weight:500;
  letter-spacing:.02em;color:var(--ink-soft);line-height:1;white-space:nowrap}
.foot-brand .brand .brand-mark{width:46px;height:46px}
.navlinks{display:flex;gap:34px;font-size:14px;font-weight:500;align-items:center}
.navlinks a{color:var(--ink-soft);transition:color .2s;position:relative;padding:4px 0;white-space:nowrap}
.navlinks a:hover{color:var(--accent)}
.navlinks a.active{color:var(--ink)}
.navlinks a.active::after{content:"";position:absolute;left:0;right:0;bottom:-2px;height:2px;background:var(--accent)}
.nav-right{display:flex;align-items:center;gap:20px}
.navcta{font-family:var(--display);font-size:13px;font-weight:500;color:var(--paper);background:var(--accent);
        padding:10px 18px;border-radius:var(--radius);transition:opacity .2s;white-space:nowrap}
.navcta:hover{opacity:.88}
.burger{display:none;width:42px;height:42px;border:1px solid var(--line-strong);border-radius:var(--radius);
        background:none;flex-direction:column;justify-content:center;align-items:center;gap:4px}
.burger span{width:18px;height:1.6px;background:var(--ink);transition:transform .25s,opacity .2s}
.burger.open span:nth-child(1){transform:translateY(5.6px) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:translateY(-5.6px) rotate(-45deg)}

.mobile-menu{display:none;position:fixed;inset:76px 0 0;z-index:99;background:var(--bg);
             flex-direction:column;padding:30px var(--pad);gap:6px;animation:fade .2s ease}
.mobile-menu.open{display:flex}
.mobile-menu a{font-family:var(--display);font-size:26px;font-weight:500;padding:14px 0;border-bottom:1px solid var(--line);color:var(--ink)}
.mobile-menu a .kr{font-size:14px;margin-left:8px}
.mobile-menu .btn{margin-top:20px;justify-content:center}
@keyframes fade{from{opacity:0}to{opacity:1}}

/* ---------- section heads ---------- */
.sec{padding:96px 0}
.sec-sm{padding:64px 0}
.sec-head{display:flex;justify-content:space-between;align-items:flex-end;gap:30px;margin-bottom:48px}
.sec-head .label{margin-bottom:16px}
.sec-head h2{font-size:clamp(30px,3.6vw,46px)}
.sec-head p{font-size:15px;color:var(--ink-soft);max-width:30ch}

/* ---------- recipe cards ---------- */
.recipe-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.rcard{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;
       display:flex;flex-direction:column;transition:transform .25s,box-shadow .25s}
.rcard:hover{transform:translateY(-6px);box-shadow:0 28px 54px -34px rgba(32,27,20,.5)}
.rcard .ph{aspect-ratio:4/3}
.rcard-body{padding:24px 24px 28px;display:flex;flex-direction:column;flex:1}
.rcard-top{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:12px;gap:12px}
.rcard-cat{font-family:var(--display);font-size:12px;font-weight:500;color:var(--accent);letter-spacing:.02em}
.rcard-time{font-size:12.5px;color:var(--ink-soft);white-space:nowrap}
.rcard h3{font-size:24px;font-weight:500;margin-bottom:5px}
.rcard .kr{font-size:13px;color:var(--accent-2);font-weight:600;letter-spacing:.04em;display:block;margin-bottom:13px}
.rcard p{font-size:14px;color:var(--ink-soft);line-height:1.6;margin-bottom:16px}
.rcard .rcard-foot{margin-top:auto;display:flex;align-items:center;gap:8px;font-family:var(--display);
                   font-size:13px;font-weight:500;color:var(--ink);transition:gap .2s}
.rcard:hover .rcard-foot{gap:13px;color:var(--accent)}
.tagrow{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:14px}
.tag{font-size:11px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-soft);
     border:1px solid var(--line);border-radius:999px;padding:4px 10px;white-space:nowrap}
.tag.spice{color:var(--accent);border-color:color-mix(in srgb,var(--accent) 40%,var(--line))}

/* ---------- footer ---------- */
footer.site{border-top:1px solid var(--line);padding:64px 0 40px;background:var(--paper)}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:48px;margin-bottom:48px}
.foot-brand .brand{font-size:23px;margin-bottom:16px}
.foot-brand p{font-size:14px;color:var(--ink-soft);max-width:32ch}
.foot-col h4{font-family:var(--display);font-size:12px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--ink);margin-bottom:18px}
.foot-col a{display:block;font-size:14px;color:var(--ink-soft);padding:6px 0;transition:color .2s}
.foot-col a:hover{color:var(--accent)}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px;
             padding-top:28px;border-top:1px solid var(--line);font-size:13px;color:var(--ink-soft)}
.foot-bottom .kr{color:var(--accent-2)}

/* ---------- newsletter band ---------- */
.news{background:var(--accent-soft)}
.news .wrap{padding:84px var(--pad);display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.news h2{font-size:clamp(30px,3.8vw,48px);max-width:13ch}
.news .ntext p{font-size:16px;color:#6a5238;margin-top:18px;max-width:36ch}
.news form{display:flex;flex-direction:column;gap:12px;max-width:400px;width:100%;justify-self:end}
.news .frow{display:flex;gap:10px}
.news input{flex:1;font-family:var(--sans);font-size:15px;padding:16px 20px;border:1px solid var(--line-strong);
            border-radius:var(--radius);background:rgba(251,248,241,.75);color:var(--ink)}
.news input:focus{outline:none;border-color:var(--accent)}
.news small{font-size:12px;color:#7c6443}
.news .ok{font-size:14px;color:var(--accent);font-weight:600;display:none}
.news.sent .ok{display:block}
.news.sent .frow,.news.sent small{display:none}

/* ---------- responsive ---------- */
@media(max-width:920px){
  :root{--pad:30px}
  .recipe-grid{grid-template-columns:repeat(2,1fr)}
  .foot-grid{grid-template-columns:1fr 1fr;gap:32px}
  .news .wrap{grid-template-columns:1fr;gap:32px}
  .news form{justify-self:start}
}
@media(max-width:680px){
  .navlinks,.nav-right .navcta{display:none}
  .burger{display:flex}
  .recipe-grid{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr 1fr}
  .sec{padding:64px 0}
}
@media(max-width:440px){
  .foot-grid{grid-template-columns:1fr}
}
/* ---------- tilbake til toppen ---------- */
.to-top{position:fixed;right:clamp(18px,4vw,40px);bottom:clamp(18px,4vw,40px);z-index:90;
  height:52px;padding:0;border-radius:26px;border:1px solid var(--line);
  background:var(--paper);color:var(--ink);cursor:pointer;
  display:flex;align-items:center;justify-content:center;overflow:hidden;
  box-shadow:0 6px 22px rgba(32,27,20,.16);
  opacity:0;visibility:hidden;transform:translateY(12px) scale(.9);
  transition:opacity .25s ease,transform .25s ease,visibility .25s,
             background .2s,color .2s,border-color .2s,padding .25s ease}
.to-top.show{opacity:1;visibility:visible;transform:translateY(0) scale(1)}
.to-top:hover{background:var(--accent-2);color:#fff;border-color:transparent;padding:0 22px 0 18px}
.to-top .tt-icon{flex:0 0 52px;width:52px;height:52px;display:flex;align-items:center;justify-content:center}
.to-top:hover .tt-icon{flex-basis:24px;width:24px}
.to-top svg{width:20px;height:20px;stroke:currentColor;stroke-width:2.4;fill:none;
  stroke-linecap:round;stroke-linejoin:round}
.to-top .tt-label{max-width:0;opacity:0;white-space:nowrap;font-size:.92rem;font-weight:600;
  letter-spacing:.01em;transition:max-width .25s ease,opacity .2s ease,margin-left .25s ease;margin-left:0}
.to-top:hover .tt-label{max-width:140px;opacity:1;margin-left:8px}
@media(max-width:680px){
  .to-top{height:46px;border-radius:23px}
  .to-top .tt-icon{flex-basis:46px;width:46px;height:46px}
  .to-top:hover{padding:0}
  .to-top:hover .tt-icon{flex-basis:46px;width:46px}
  .to-top:hover .tt-label{max-width:0;opacity:0;margin-left:0}
}

@media(prefers-reduced-motion:reduce){
  *{animation-duration:.01ms!important;transition-duration:.01ms!important;scroll-behavior:auto}
}
