
    /* ─── RESET ─────────────────────────────────────── */
    *, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
    html { scroll-behavior: smooth; }

    /* ─── TOKENS ─────────────────────────────────────
       Exact palette sampled from hrima.is
       Main bg:   #FAD8DC  (hlý bleikrós)
       Accent:    #E8839A  (dökkari bleikur)
       Card bg:   #FDE8EB  (ljósari bleikur)
       Dark:      #3A1A22  (djúpur rauðbrúnn fyrir texta)
       White:     #FFFAFC
    ──────────────────────────────────────────────── */
    :root {
      --bg:        #FAD8DC;
      --bg-light:  #FDE8EB;
      --bg-white:  #FFFAFC;
      --accent:    #E8839A;
      --accent-dk: #C45E78;
      --dark:      #3A1A22;
      --mid:       rgba(58,26,34,0.55);
      --faint:     rgba(58,26,34,0.25);
      --serif:     'Playfair Display', Georgia, serif;
      --sans:      'Inter', system-ui, sans-serif;
    }

    body {
      font-family: var(--sans);
      background: var(--bg);
      color: var(--dark);
      min-height: 100vh;
      overflow-x: hidden;
    }

    /* ─── NAV ────────────────────────────────────────── */
    nav {
      display: flex;
      justify-content: space-between;
      align-items: center;
      padding: 1.4rem 3rem;
      background: var(--bg);
      border-bottom: 1px solid rgba(232,131,154,0.25);
      position: sticky;
      top: 0;
      z-index: 100;
    }
    .nav-logo {
      font-family: var(--serif);
      font-size: 1.5rem;
      letter-spacing: 0.2em;
      color: var(--dark);
      font-weight: 400;
      text-decoration: none;
    }
    .nav-links {
      display: flex;
      gap: 2.2rem;
      list-style: none;
    }
    .nav-links a {
      font-size: 0.75rem;
      letter-spacing: 0.13em;
      text-transform: uppercase;
      color: var(--mid);
      text-decoration: none;
      transition: color 0.2s;
    }
    .nav-links a:hover { color: var(--accent-dk); }
    .nav-cart {
      font-size: 0.75rem;
      letter-spacing: 0.1em;
      text-transform: uppercase;
      color: var(--mid);
      cursor: pointer;
      transition: color 0.2s;
    }
    .nav-cart:hover { color: var(--accent-dk); }

    /* ─── HERO ───────────────────────────────────────── */
    .hero {
      position: relative;
      min-height: 88vh;
      display: grid;
      grid-template-columns: 1fr 1fr;
      align-items: center;
      overflow: hidden;
    }
    .hero-bg-img {
      position: absolute;
      inset: 0;
      width: 100%;
      height: 100%;
      object-fit: cover;
      object-position: center;
      z-index: 0;
      filter: brightness(0.9) saturate(1.05);
    }
    .hero-overlay {
      position: absolute;
      inset: 0;
      background: linear-gradient(to right, rgba(250,216,220,0.62) 35%, rgba(250,216,220,0.08) 100%);
      z-index: 1;
    }
    .hero-content {
      position: relative;
      z-index: 2;
      padding: 5rem 3rem 5rem 3rem;
    }
    .hero-eyebrow {
      font-size: 0.68rem;
      letter-spacing: 0.24em;
      text-transform: uppercase;
      color: var(--accent-dk);
      margin-bottom: 1.2rem;
    }
    .hero-title {
      font-family: var(--serif);
      font-size: clamp(2.8rem, 5vw, 4.2rem);
      font-weight: 400;
      line-height: 1.1;
      color: var(--dark);
      margin-bottom: 1.4rem;
    }
    .hero-title em {
      font-style: italic;
      color: var(--accent-dk);
    }
    .hero-body {
      font-size: 0.95rem;
      line-height: 1.8;
      color: var(--mid);
      max-width: 400px;
      margin-bottom: 2.2rem;
    }
    .btn {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      background: var(--accent-dk);
      color: #fff;
      font-family: var(--sans);
      font-size: 0.75rem;
      letter-spacing: 0.13em;
      text-transform: uppercase;
      padding: 0.85rem 2rem;
      border: none;
      cursor: pointer;
      text-decoration: none;
      transition: background 0.2s;
    }
    .btn:hover { background: #a84b65; }
    .btn-outline {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      background: transparent;
      border: 1px solid var(--accent);
      color: var(--accent-dk);
      font-family: var(--sans);
      font-size: 0.75rem;
      letter-spacing: 0.13em;
      text-transform: uppercase;
      padding: 0.85rem 2rem;
      cursor: pointer;
      text-decoration: none;
      transition: all 0.2s;
    }
    .btn-outline:hover { background: var(--accent); color: #fff; }
    .hero-btns { display: flex; gap: 1rem; flex-wrap: wrap; }

    /* ─── SLIDESHOW / FLAVORS ────────────────────────── */
    .flavors {
      padding: 4rem 3rem;
      background: var(--bg-light);
    }
    .section-header {
      display: flex;
      justify-content: space-between;
      align-items: baseline;
      margin-bottom: 2.5rem;
    }
    .section-title {
      font-family: var(--serif);
      font-size: 2rem;
      font-weight: 400;
      color: var(--dark);
    }
    .see-all {
      font-size: 0.7rem;
      letter-spacing: 0.14em;
      text-transform: uppercase;
      color: var(--faint);
      text-decoration: none;
      transition: color 0.2s;
    }
    .see-all:hover { color: var(--accent-dk); }

    .flavor-grid {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 1.2rem;
    }
    .flavor-card {
      background: var(--bg-white);
      border: 1px solid rgba(232,131,154,0.2);
      overflow: hidden;
      cursor: pointer;
      transition: box-shadow 0.2s, transform 0.2s;
      text-decoration: none;
      color: inherit;
      display: block;
    }
    .flavor-card:hover {
      box-shadow: 0 6px 28px rgba(196,94,120,0.15);
      transform: translateY(-3px);
    }
    .flavor-img {
      width: 100%;
      aspect-ratio: 4/3;
      object-fit: cover;
      display: block;
    }
    .flavor-body { padding: 1.5rem; }
    .flavor-tags {
      display: flex;
      flex-wrap: wrap;
      gap: 0.4rem;
      margin-bottom: 0.9rem;
    }
    .tag {
      font-size: 0.6rem;
      letter-spacing: 0.12em;
      text-transform: uppercase;
      padding: 3px 8px;
      border: 1px solid rgba(196,94,120,0.35);
      color: var(--accent-dk);
      background: rgba(232,131,154,0.07);
    }
    .flavor-name {
      font-family: var(--serif);
      font-size: 1.15rem;
      color: var(--dark);
      margin-bottom: 0.5rem;
    }
    .flavor-desc {
      font-size: 0.8rem;
      color: var(--mid);
      line-height: 1.65;
      margin-bottom: 1.3rem;
    }
    .flavor-footer {
      display: flex;
      justify-content: space-between;
      align-items: center;
    }
    .flavor-price { font-size: 0.9rem; font-weight: 500; color: var(--dark); }
    .add-btn {
      width: 34px;
      height: 34px;
      border: 1px solid rgba(196,94,120,0.35);
      background: transparent;
      color: var(--accent-dk);
      font-size: 1.3rem;
      line-height: 1;
      display: flex;
      align-items: center;
      justify-content: center;
      cursor: pointer;
      transition: background 0.2s, color 0.2s;
    }
    .add-btn:hover { background: var(--accent-dk); color: #fff; border-color: var(--accent-dk); }

    /* ─── ABOUT ──────────────────────────────────────── */
    .about {
      display: grid;
      grid-template-columns: 1fr 1fr;
      min-height: 480px;
    }
    .about-img-wrap { position: relative; overflow: hidden; }
    .about-img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      display: block;
    }
    .about-content {
      background: var(--bg);
      padding: 4rem 3.5rem;
      display: flex;
      flex-direction: column;
      justify-content: center;
    }
    .about-eyebrow {
      font-size: 0.68rem;
      letter-spacing: 0.22em;
      text-transform: uppercase;
      color: var(--accent-dk);
      margin-bottom: 1rem;
    }
    .about-title {
      font-family: var(--serif);
      font-size: 2.2rem;
      font-weight: 400;
      line-height: 1.2;
      color: var(--dark);
      margin-bottom: 1.5rem;
    }
    .about-body {
      font-size: 0.9rem;
      line-height: 1.85;
      color: var(--mid);
      margin-bottom: 2rem;
    }
    .stat-row { display: flex; gap: 2.5rem; margin-bottom: 2rem; }
    .stat-num {
      font-family: var(--serif);
      font-size: 2.6rem;
      color: var(--accent-dk);
      line-height: 1;
      margin-bottom: 0.3rem;
    }
    .stat-label {
      font-size: 0.68rem;
      letter-spacing: 0.12em;
      text-transform: uppercase;
      color: var(--faint);
    }

    /* ─── SAGA ───────────────────────────────────────── */
    .saga {
      position: relative;
      min-height: 380px;
      display: flex;
      align-items: center;
      overflow: hidden;
    }
    .saga-bg {
      position: absolute;
      inset: 0;
      width: 100%;
      height: 100%;
      object-fit: cover;
      filter: brightness(0.7) saturate(0.9);
    }
    .saga-overlay {
      position: absolute;
      inset: 0;
      background: rgba(250,216,220,0.55);
    }
    .saga-content {
      position: relative;
      z-index: 2;
      padding: 3rem;
      text-align: center;
      width: 100%;
    }
    .saga-title {
      font-family: var(--serif);
      font-size: 2.8rem;
      font-weight: 400;
      color: var(--dark);
      margin-bottom: 1.5rem;
    }

    /* ─── FAQ ────────────────────────────────────────── */
    .faq {
      padding: 4rem 3rem;
      background: var(--bg-light);
    }
    .faq-title {
      font-family: var(--serif);
      font-size: 2rem;
      font-style: italic;
      font-weight: 400;
      color: var(--dark);
      margin-bottom: 2.5rem;
    }
    .faq-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 0 3rem; }
    .faq-item { border-top: 1px solid rgba(232,131,154,0.3); padding: 1.4rem 0; }
    .faq-q {
      font-size: 0.9rem;
      font-weight: 500;
      color: var(--dark);
      margin-bottom: 0.6rem;
    }
    .faq-a {
      font-size: 0.82rem;
      color: var(--mid);
      line-height: 1.7;
    }
    .faq-list {
      margin-top: 0.6rem;
      padding-left: 1.1rem;
      list-style: disc;
    }
    .faq-list li { font-size: 0.82rem; color: var(--mid); line-height: 1.8; }

    /* ─── CONTACT ────────────────────────────────────── */
    .contact {
      padding: 4rem 3rem;
      background: var(--bg);
      text-align: center;
    }
    .contact-title {
      font-family: var(--serif);
      font-size: 2rem;
      font-weight: 400;
      color: var(--dark);
      margin-bottom: 1rem;
    }
    .contact-body {
      font-size: 0.9rem;
      color: var(--mid);
      line-height: 1.8;
      margin-bottom: 2rem;
    }
    .contact-details {
      display: flex;
      justify-content: center;
      gap: 3rem;
      flex-wrap: wrap;
      margin-top: 2rem;
    }
    .contact-item { text-align: center; }
    .contact-label {
      font-size: 0.65rem;
      letter-spacing: 0.18em;
      text-transform: uppercase;
      color: var(--faint);
      margin-bottom: 0.4rem;
    }
    .contact-value {
      font-size: 0.9rem;
      color: var(--dark);
    }
    .contact-value a { color: var(--accent-dk); text-decoration: none; }

    /* ─── FOOTER ─────────────────────────────────────── */
    footer {
      padding: 2rem 3rem;
      background: var(--bg-light);
      border-top: 1px solid rgba(232,131,154,0.2);
      display: flex;
      justify-content: space-between;
      align-items: center;
      flex-wrap: wrap;
      gap: 1rem;
    }
    .footer-logo {
      font-family: var(--serif);
      font-size: 1rem;
      letter-spacing: 0.2em;
      color: var(--faint);
    }
    .footer-copy {
      font-size: 0.72rem;
      color: var(--faint);
      text-align: center;
    }
    .footer-social { display: flex; gap: 0.8rem; }
    .social-link {
      width: 36px;
      height: 36px;
      border: 1px solid rgba(232,131,154,0.3);
      display: flex;
      align-items: center;
      justify-content: center;
      color: var(--faint);
      text-decoration: none;
      font-size: 14px;
      font-weight: 600;
      transition: border-color 0.2s, color 0.2s;
    }
    .social-link:hover { border-color: var(--accent-dk); color: var(--accent-dk); }

    /* ─── DIVIDER ─────────────────────────────────────── */
    hr { border: none; border-top: 1px solid rgba(232,131,154,0.2); margin: 0 3rem; }

    /* ─── PAGE HERO (subpages) ───────────────────────── */
    .page-hero {
      position: relative;
      min-height: 46vh;
      display: flex;
      align-items: center;
      overflow: hidden;
    }
    .page-hero-bg {
      position: absolute;
      inset: 0;
      width: 100%;
      height: 100%;
      object-fit: cover;
      filter: brightness(0.92) saturate(1.05);
    }
    .page-hero-overlay {
      position: absolute;
      inset: 0;
      background: linear-gradient(to bottom, rgba(250,216,220,0.35) 40%, rgba(250,216,220,0.85) 100%);
    }
    .page-hero-content {
      position: relative;
      z-index: 2;
      padding: 3rem;
      width: 100%;
      text-align: center;
    }
    .page-eyebrow {
      font-size: 0.68rem;
      letter-spacing: 0.24em;
      text-transform: uppercase;
      color: var(--accent-dk);
      margin-bottom: 1rem;
    }
    .page-title {
      font-family: var(--serif);
      font-size: clamp(2.2rem, 4.5vw, 3.4rem);
      font-weight: 400;
      color: var(--dark);
    }
    .breadcrumb {
      font-size: 0.72rem;
      letter-spacing: 0.08em;
      color: var(--mid);
      margin-top: 1.2rem;
    }
    .breadcrumb a { color: var(--accent-dk); text-decoration: none; }
    .breadcrumb a:hover { text-decoration: underline; }

    /* ─── PRODUCT DETAIL ──────────────────────────────── */
    .product-main {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 3.5rem;
      padding: 4rem 3rem;
      max-width: 1200px;
      margin: 0 auto;
      align-items: start;
    }
    .product-gallery {
      width: 100%;
    }
    .product-info { padding-top: 0.5rem; }
    .product-name {
      font-family: var(--serif);
      font-size: 2.1rem;
      font-weight: 400;
      color: var(--dark);
      margin-bottom: 0.6rem;
    }
    .product-price-tag {
      font-size: 1.1rem;
      color: var(--accent-dk);
      font-weight: 500;
      margin-bottom: 1.6rem;
    }
    .product-desc {
      font-size: 0.95rem;
      line-height: 1.85;
      color: var(--dark);
      margin-bottom: 1.6rem;
    }
    .product-block {
      background: var(--bg-white);
      border: 1px solid rgba(232,131,154,0.2);
      padding: 1.4rem 1.6rem;
      margin-bottom: 1.2rem;
    }
    .product-block-title {
      font-size: 0.7rem;
      letter-spacing: 0.14em;
      text-transform: uppercase;
      color: var(--accent-dk);
      margin-bottom: 0.6rem;
      font-weight: 600;
    }
    .product-block-text {
      font-size: 0.85rem;
      line-height: 1.7;
      color: var(--mid);
    }
    .nutrition-table {
      width: 100%;
      border-collapse: collapse;
      font-size: 0.83rem;
    }
    .nutrition-table tr { border-bottom: 1px solid rgba(232,131,154,0.18); }
    .nutrition-table tr:last-child { border-bottom: none; }
    .nutrition-table td { padding: 0.5rem 0; color: var(--mid); }
    .nutrition-table td:last-child { text-align: right; color: var(--dark); font-weight: 500; }
    .availability-note {
      font-size: 0.82rem;
      color: var(--mid);
      line-height: 1.7;
      font-style: italic;
      border-left: 2px solid var(--accent-dk);
      padding-left: 1rem;
      margin-top: 1.6rem;
    }
    .related-flavors {
      padding: 0 3rem 4rem;
      max-width: 1200px;
      margin: 0 auto;
    }

    /* ─── STORY / NARRATIVE PAGES ─────────────────────── */
    .story-main {
      max-width: 760px;
      margin: 0 auto;
      padding: 4rem 3rem 5rem;
    }
    .story-block { margin-bottom: 2.6rem; }
    .story-block h2 {
      font-family: var(--serif);
      font-size: 1.6rem;
      font-weight: 400;
      color: var(--dark);
      margin-bottom: 1rem;
    }
    .story-block p {
      font-size: 0.95rem;
      line-height: 1.9;
      color: var(--mid);
      margin-bottom: 1rem;
    }
    .story-pullquote {
      font-family: var(--serif);
      font-style: italic;
      font-size: 1.4rem;
      color: var(--accent-dk);
      text-align: center;
      border-top: 1px solid rgba(232,131,154,0.3);
      border-bottom: 1px solid rgba(232,131,154,0.3);
      padding: 2rem 1rem;
      margin: 2.5rem 0;
      line-height: 1.5;
    }
    .story-cta {
      text-align: center;
      margin-top: 2.5rem;
    }
    .mini-form {
      background: var(--bg-light);
      border: 1px solid rgba(232,131,154,0.25);
      padding: 2.2rem;
      margin-top: 2.5rem;
    }
    .mini-form h3 {
      font-family: var(--serif);
      font-size: 1.25rem;
      font-weight: 400;
      color: var(--dark);
      margin-bottom: 0.4rem;
      text-align: center;
    }
    .mini-form p {
      font-size: 0.85rem;
      color: var(--mid);
      text-align: center;
      margin-bottom: 1.4rem;
    }
    .mini-form-row {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 0.8rem;
      margin-bottom: 0.8rem;
    }
    .mini-form input, .mini-form textarea {
      width: 100%;
      padding: 0.7rem 0.9rem;
      border: 1px solid rgba(232,131,154,0.35);
      background: var(--bg-white);
      font-family: var(--sans);
      font-size: 0.85rem;
      color: var(--dark);
    }
    .mini-form textarea { resize: vertical; min-height: 90px; margin-bottom: 0.8rem; }
    .mini-form .btn { width: 100%; justify-content: center; border: none; cursor: pointer; }

    /* ─── RESPONSIVE ─────────────────────────────────── */
    @media (max-width: 768px) {
      nav { padding: 1rem 1.5rem; }
      .nav-links { display: none; }
      .hero { grid-template-columns: 1fr; min-height: auto; }
      .hero-content { padding: 3rem 1.5rem; }
      .hero-overlay {
        background: linear-gradient(to bottom, rgba(250,216,220,0.92) 60%, rgba(250,216,220,0.6) 100%);
      }
      .flavors, .faq, .contact { padding: 3rem 1.5rem; }
      .flavor-grid { grid-template-columns: 1fr; }
      .faq-grid { grid-template-columns: 1fr; }
      .about { grid-template-columns: 1fr; }
      .about-img-wrap { height: 280px; }
      .about-content { padding: 2.5rem 1.5rem; }
      .saga-content { padding: 2rem 1.5rem; }
      .contact-details { gap: 1.5rem; }
      footer { padding: 1.5rem; flex-direction: column; text-align: center; }
      hr { margin: 0 1.5rem; }
      .product-main { grid-template-columns: 1fr; padding: 2.5rem 1.5rem; gap: 2rem; }
      .page-hero-content { padding: 2rem 1.5rem; }
      .story-main { padding: 3rem 1.5rem 3.5rem; }
      .mini-form-row { grid-template-columns: 1fr; }
      .related-flavors { padding: 0 1.5rem 3rem; }
    }
  
