/* ==========================================================================
   Halmahera — design system
   ========================================================================== */
:root{
  --primary:#bc5217;
  --primary-dark:#a4470f;
  --cream:#f4edd6;
  --offwhite:#fbf8ef;
  --ink:#2b1d14;
  --text:#3a2a1e;
  --muted:#6b5a48;
  --muted2:#8a7c68;
  --footer-text:#f2e3d0;
  --line:rgba(43,29,20,0.10);
  --maxw:1240px;
  --serif:'Playfair Display',Georgia,serif;
  --sans:'Karla',system-ui,-apple-system,sans-serif;
}
*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;font-family:var(--sans);color:var(--ink);background:var(--cream);
  -webkit-font-smoothing:antialiased;line-height:1.5;
}
img{max-width:100%;display:block;}
a{color:inherit;}
.wrap{max-width:var(--maxw);margin:0 auto;padding-left:32px;padding-right:32px;}

/* ---- Header ---- */
.site-header{position:sticky;top:0;z-index:50;background:rgba(244,237,214,0.92);backdrop-filter:blur(8px);border-bottom:1px solid var(--line);}
.site-header .wrap{display:flex;align-items:center;justify-content:space-between;gap:24px;padding-top:16px;padding-bottom:16px;}
.brand{display:flex;align-items:center;gap:12px;text-decoration:none;color:var(--primary);}
.brand img{width:40px;height:40px;}
.brand span{font-family:var(--serif);font-weight:700;font-size:26px;letter-spacing:.2px;color:var(--primary);}
.nav{display:flex;align-items:center;gap:28px;font-size:15px;font-weight:600;}
.nav a{color:var(--ink);text-decoration:none;}
.nav a:hover{color:var(--primary);}
.nav a.active{color:var(--primary);}
.nav .btn-eshop{background:var(--primary);color:var(--cream);padding:10px 20px;border-radius:999px;font-weight:700;}
.nav .btn-eshop:hover{background:var(--primary-dark);color:var(--cream);}
.nav-toggle{display:none;background:none;border:0;cursor:pointer;padding:6px;}
.nav-toggle svg{display:block;}

/* ---- Buttons ---- */
.btn{display:inline-flex;align-items:center;gap:10px;text-decoration:none;font-weight:700;font-size:16px;padding:16px 30px;border-radius:999px;border:0;cursor:pointer;font-family:inherit;transition:background .15s,border-color .15s,color .15s;}
.btn-primary{background:var(--primary);color:var(--cream);}
.btn-primary:hover{background:var(--primary-dark);}
.btn-ghost{background:transparent;color:var(--ink);border:1.5px solid rgba(43,29,20,0.25);}
.btn-ghost:hover{border-color:var(--primary);color:var(--primary);}
.btn-cream{background:var(--cream);color:var(--primary);}
.btn-cream:hover{background:#fff;}
.btn-sm{padding:13px 24px;font-size:15px;}

/* ---- Section helpers ---- */
.eyebrow{font-size:13px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--primary);margin-bottom:14px;}
.eyebrow-line{display:inline-flex;align-items:center;gap:8px;}
.eyebrow-line::before{content:"";width:26px;height:1px;background:var(--primary);}
h1,h2,h3{font-family:var(--serif);margin:0;}
.section{padding-top:80px;padding-bottom:80px;}
.section-tight{padding-top:56px;padding-bottom:56px;}
.bg-offwhite{background:var(--offwhite);border-top:1px solid var(--line);border-bottom:1px solid var(--line);}
.bg-primary{background:var(--primary);color:var(--cream);}
.bg-ink{background:var(--ink);color:var(--cream);}
.lead{font-size:19px;line-height:1.6;color:var(--muted);}
.center{text-align:center;}
.mx-narrow{max-width:38em;margin-left:auto;margin-right:auto;}

/* ---- Hero (home) ---- */
.hero{display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center;padding-top:72px;padding-bottom:80px;}
.hero h1{font-weight:700;font-size:64px;line-height:1.04;letter-spacing:-.5px;margin:0 0 24px;}
.hero .accent{font-style:italic;color:var(--primary);}
.hero p{font-size:19px;line-height:1.6;max-width:30em;color:var(--muted);margin:0 0 36px;}
.hero-actions{display:flex;gap:16px;flex-wrap:wrap;}
.hero-media{position:relative;}
.hero-media .offset{position:absolute;inset:auto -18px -18px auto;width:78%;height:82%;background:var(--primary);border-radius:20px;z-index:0;}
.hero-media img{position:relative;z-index:1;width:100%;aspect-ratio:4/5;object-fit:cover;border-radius:20px;box-shadow:0 30px 60px -30px rgba(43,29,20,0.5);}

/* ---- Values strip ---- */
.values{display:grid;grid-template-columns:repeat(4,1fr);gap:36px;}
.values .ico{margin-bottom:14px;line-height:0;}
.values h3{font-family:var(--sans);font-size:18px;font-weight:700;margin:0 0 6px;}
.values p{font-size:14.5px;line-height:1.55;margin:0;}
.values.on-primary p{color:#f2e3d0;}

/* ---- Product / set cards ---- */
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;}
.card{background:var(--offwhite);border:1px solid rgba(43,29,20,0.08);border-radius:16px;overflow:hidden;display:flex;flex-direction:column;text-decoration:none;color:inherit;transition:box-shadow .18s,transform .18s;}
.card:hover{box-shadow:0 20px 40px -24px rgba(43,29,20,0.45);transform:translateY(-3px);}
.card .thumb{aspect-ratio:1/1;background:var(--cream);overflow:hidden;position:relative;}
.card .thumb img{width:100%;height:100%;object-fit:cover;}
.card-body{padding:18px 18px 20px;display:flex;flex-direction:column;flex:1;}
.card-title{font-family:var(--serif);font-weight:600;font-size:20px;margin:0;}
.card-blurb{font-size:13.5px;line-height:1.5;color:var(--muted);margin:8px 0 16px;}
.card-foot{margin-top:auto;display:flex;align-items:center;justify-content:space-between;}
.price{font-weight:700;font-size:17px;color:var(--primary);}
.detail-link{font-size:13.5px;font-weight:700;color:var(--ink);}
.weight{font-size:12px;color:var(--muted2);font-weight:600;white-space:nowrap;}
.badge-sold{position:absolute;top:12px;left:12px;background:rgba(43,29,20,0.85);color:var(--cream);font-size:11.5px;font-weight:700;padding:5px 11px;border-radius:999px;}
.card.set{background:var(--cream);}
.card.set .card-title{font-size:24px;}
.card.set .thumb{aspect-ratio:4/3;}

/* ---- Page head ---- */
.page-head{padding-top:64px;padding-bottom:20px;}
.page-head h1{font-weight:700;font-size:56px;line-height:1.04;letter-spacing:-.5px;margin:0 0 18px;}

/* ---- Controls (produkty) ---- */
.controls{display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap;border-bottom:1px solid rgba(43,29,20,0.12);padding-bottom:20px;}
.search{display:flex;align-items:center;gap:12px;background:var(--offwhite);border:1px solid rgba(43,29,20,0.14);border-radius:999px;padding:11px 18px;flex:1;max-width:380px;min-width:260px;}
.search input{border:0;background:transparent;outline:none;font-family:inherit;font-size:15.5px;color:var(--ink);width:100%;}
.search input::placeholder{color:#a99878;}
.control-right{display:flex;align-items:center;gap:16px;flex-wrap:wrap;}
.count{font-size:14.5px;color:var(--muted2);font-weight:600;}
select.sort{font-family:inherit;font-size:14.5px;font-weight:600;color:var(--ink);background:var(--offwhite);border:1px solid rgba(43,29,20,0.14);border-radius:999px;padding:11px 18px;cursor:pointer;outline:none;}
.empty{text-align:center;padding:60px 0;color:var(--muted2);font-size:17px;}

/* ---- Story / quote ---- */
.story{max-width:820px;margin:0 auto;font-size:19px;line-height:1.75;color:var(--text);}
.story p{margin:0 0 24px;}
.story .pull{font-family:var(--serif);font-style:italic;font-size:26px;line-height:1.4;color:var(--primary);}

/* ---- Reviews ---- */
.reviews{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;}
.review{background:rgba(244,237,214,0.10);border:1px solid rgba(244,237,214,0.2);border-radius:18px;padding:30px;}
.review .stars{font-size:20px;margin-bottom:14px;color:#f4d9b8;}
.review p{font-size:16.5px;line-height:1.6;margin:0 0 18px;}
.review .who{font-weight:700;font-size:15px;}

/* ---- Instagram novinky ---- */
.ig-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.ig-card{background:var(--offwhite);border:1px solid rgba(43,29,20,0.08);border-radius:16px;overflow:hidden;display:flex;flex-direction:column;text-decoration:none;color:inherit;transition:box-shadow .18s,transform .18s;}
.ig-card:hover{box-shadow:0 20px 40px -24px rgba(43,29,20,0.45);transform:translateY(-3px);}
.ig-photo{aspect-ratio:4/3;overflow:hidden;background:var(--cream);position:relative;}
.ig-photo img{width:100%;height:100%;object-fit:cover;}
.ig-tag{position:absolute;top:12px;left:12px;background:rgba(188,82,23,0.95);color:var(--cream);font-size:11.5px;font-weight:700;letter-spacing:.5px;padding:5px 11px;border-radius:999px;}
.ig-body{padding:18px 20px 20px;display:flex;flex-direction:column;flex:1;}
.ig-date{font-size:12.5px;font-weight:700;color:var(--muted2);margin-bottom:8px;}
.ig-body p{font-size:15px;line-height:1.55;color:var(--muted);margin:0 0 16px;}
.ig-more{margin-top:auto;font-size:14px;font-weight:700;color:var(--primary);}

/* ---- Footer ---- */
.site-footer{background:var(--primary-dark);color:var(--footer-text);}
.site-footer .cols{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;padding-top:64px;padding-bottom:40px;}
.site-footer .brandline{display:flex;align-items:center;gap:12px;margin-bottom:18px;}
.site-footer .brandline img{width:38px;height:38px;}
.site-footer .brandline span{font-family:var(--serif);font-weight:700;font-size:24px;color:var(--cream);}
.site-footer p{font-size:15px;line-height:1.6;max-width:26em;margin:0;}
.site-footer h4{color:var(--cream);font-size:14px;letter-spacing:1px;text-transform:uppercase;margin:0 0 16px;font-family:var(--sans);}
.footcol{display:flex;flex-direction:column;gap:10px;font-size:15px;}
.footcol a{color:var(--footer-text);text-decoration:none;}
.footcol a:hover{color:var(--cream);}
.footinfo{font-size:15px;line-height:1.7;}
.footinfo a{color:var(--cream);text-decoration:none;}
.footbar{border-top:1px solid rgba(244,237,214,0.18);}
.footbar .wrap{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;font-size:13.5px;padding-top:20px;padding-bottom:20px;}

/* ---- Breadcrumb ---- */
.crumb{font-size:14px;color:var(--muted2);padding-top:24px;}
.crumb a{color:var(--muted2);text-decoration:none;}
.crumb a:hover{color:var(--primary);}
.crumb .sep{margin:0 8px;}
.crumb .cur{color:var(--ink);font-weight:600;}

/* ---- Product detail ---- */
.pd{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:start;padding-top:32px;padding-bottom:80px;}
.gallery-main{aspect-ratio:1/1;background:var(--offwhite);border:1px solid rgba(43,29,20,0.08);border-radius:20px;overflow:hidden;}
.gallery-main img{width:100%;height:100%;object-fit:cover;}
.thumbs{display:flex;gap:12px;margin-top:14px;flex-wrap:wrap;}
.thumbs button{width:76px;height:76px;padding:0;border-radius:12px;overflow:hidden;cursor:pointer;background:var(--offwhite);border:2px solid rgba(43,29,20,0.12);}
.thumbs button.active{border-color:var(--primary);}
.thumbs button img{width:100%;height:100%;object-fit:cover;}
.pd h1{font-weight:700;font-size:46px;line-height:1.05;letter-spacing:-.5px;margin:0 0 16px;}
.pd-meta{display:flex;align-items:center;gap:16px;margin-bottom:24px;flex-wrap:wrap;}
.pd-price{font-family:var(--serif);font-weight:700;font-size:32px;color:var(--primary);}
.pill{font-size:14px;font-weight:600;color:var(--muted);background:var(--offwhite);border:1px solid rgba(43,29,20,0.12);padding:6px 14px;border-radius:999px;}
.avail{font-size:14px;font-weight:700;display:inline-flex;align-items:center;gap:6px;}
.avail.in{color:#1f7a3d;}
.avail.out{color:#9a3412;}
.pd-intro{font-size:17.5px;line-height:1.65;color:var(--text);margin:0 0 28px;}
.pd-actions{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:32px;}
.slozeni-box{background:var(--offwhite);border:1px solid rgba(43,29,20,0.08);border-radius:16px;padding:24px 26px;margin-bottom:20px;}
.slozeni-box h3{font-family:var(--sans);font-size:13px;font-weight:700;letter-spacing:1.2px;text-transform:uppercase;color:var(--primary);margin:0 0 10px;}
.slozeni-box p{font-size:15.5px;line-height:1.6;color:var(--text);margin:0;}
.tags{display:flex;gap:12px;flex-wrap:wrap;font-size:13.5px;color:var(--muted2);}
.tag{background:var(--offwhite);border:1px solid rgba(43,29,20,0.10);padding:6px 12px;border-radius:8px;}

/* Feature block (balení / services) */
.block-sep{border-top:1px solid rgba(43,29,20,0.14);padding-top:48px;}
.feature{display:grid;grid-template-columns:1fr 1fr;gap:52px;align-items:center;}
.feature h3{font-weight:700;font-size:30px;line-height:1.15;letter-spacing:-.3px;margin:0 0 16px;}
.feature p{font-size:17px;line-height:1.7;color:var(--text);margin:0 0 26px;}
.feature .media{border-radius:20px;overflow:hidden;border:1px solid rgba(43,29,20,0.08);}
.points{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.point{display:flex;align-items:center;gap:12px;}
.point .num{width:32px;height:32px;border-radius:50%;background:var(--primary);color:var(--cream);font-weight:700;font-size:14.5px;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.point span:last-child{font-size:16px;font-weight:600;}

/* Services mini-cards (on set detail + sluzby) */
.svc-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.svc{background:var(--offwhite);border:1px solid rgba(43,29,20,0.08);border-radius:14px;padding:20px;}
.svc svg{margin-bottom:10px;}
.svc-title{font-size:16px;font-weight:700;margin-bottom:4px;}
.svc-desc{font-size:14px;color:var(--muted);line-height:1.45;}

/* About feature block */
.about-feature{display:grid;grid-template-columns:1fr 1fr;gap:52px;align-items:center;}
.about-feature .media img{width:100%;aspect-ratio:4/3;object-fit:cover;object-position:center 22%;border-radius:20px;display:block;}
.about-feature h3{font-weight:700;font-size:30px;line-height:1.15;letter-spacing:-.3px;margin:0 0 16px;}
.about-feature p{font-size:17px;line-height:1.7;color:var(--text);margin:0 0 16px;}

/* ---- Masonry (o nás) ---- */
.masonry{column-count:4;column-gap:16px;}
.masonry img{width:100%;border-radius:14px;margin:0 0 16px;display:block;break-inside:avoid;}

/* ---- Uniform photo grid (sluzby) ---- */
.photo-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:16px;}
.photo-grid img{width:100%;aspect-ratio:1/1;object-fit:cover;border-radius:14px;}

/* ---- Sluzby service cards (big) ---- */
.svc-big-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;}
.svc-big{background:var(--offwhite);border:1px solid rgba(43,29,20,0.08);border-radius:20px;padding:40px;}
.svc-big .ico{width:56px;height:56px;border-radius:14px;background:var(--primary);display:flex;align-items:center;justify-content:center;margin-bottom:22px;}
.svc-big h2{font-weight:700;font-size:26px;margin:0 0 12px;}
.svc-big p{font-size:16px;line-height:1.6;color:var(--muted);margin:0 0 18px;}
.svc-big ul{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:9px;}
.svc-big li{font-size:15px;color:var(--text);display:flex;gap:10px;}
.svc-big li::before{content:"✦";color:var(--primary);font-weight:700;}
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;}
.step .n{font-family:var(--serif);font-size:40px;color:var(--primary);margin-bottom:10px;}
.step h3{font-family:var(--sans);font-size:19px;font-weight:700;margin:0 0 8px;}
.step p{font-size:15.5px;line-height:1.6;color:var(--muted);margin:0;}

/* ---- Contact ---- */
.contact{display:grid;grid-template-columns:.9fr 1.1fr;gap:56px;align-items:start;}
.contact-card{background:var(--offwhite);border:1px solid rgba(43,29,20,0.08);border-radius:18px;padding:28px;}
.contact-card h3{font-family:var(--sans);font-size:13px;font-weight:700;letter-spacing:1.2px;text-transform:uppercase;color:var(--primary);margin:0 0 14px;}
.contact-row{display:flex;align-items:center;gap:14px;text-decoration:none;color:var(--ink);margin-bottom:14px;}
.contact-row:last-child{margin-bottom:0;}
.contact-row:hover{color:var(--primary);}
.contact-row .ico{width:42px;height:42px;border-radius:11px;background:var(--primary);display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.contact-row .lbl{display:block;font-size:12.5px;color:var(--muted2);font-weight:600;}
.contact-row .val{font-size:17px;font-weight:700;}
.contact-stack{display:flex;flex-direction:column;gap:20px;}
.form-card{background:var(--offwhite);border:1px solid rgba(43,29,20,0.08);border-radius:22px;padding:40px;}
.form-card h2{font-weight:700;font-size:28px;margin:0 0 24px;}
.field{display:block;margin-bottom:16px;}
.field > span{display:block;font-size:13.5px;font-weight:700;margin-bottom:7px;}
.field input,.field textarea,.field select{width:100%;font-family:inherit;font-size:15.5px;color:var(--ink);background:var(--cream);border:1.5px solid rgba(43,29,20,0.15);border-radius:11px;padding:13px 15px;outline:none;}
.field textarea{resize:vertical;}
.field input:focus,.field textarea:focus,.field select:focus{border-color:var(--primary);}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden;}
.form-note{font-size:13px;color:var(--muted2);margin:16px 0 0;text-align:center;}
.form-msg{font-size:15px;margin:0 0 16px;padding:12px 16px;border-radius:11px;display:none;}
.form-msg.err{background:#fbeae2;color:#9a3412;border:1px solid #e7b9a3;}
.sent{text-align:center;padding:40px 0;}
.sent .check{width:72px;height:72px;margin:0 auto 22px;border-radius:50%;background:var(--primary);display:flex;align-items:center;justify-content:center;}
.sent h2{font-weight:700;font-size:30px;margin:0 0 10px;}
.sent p{font-size:17px;color:var(--muted);margin:0 0 24px;}
.hours{background:var(--primary);color:var(--cream);border-radius:18px;padding:28px;}
.hours h3{font-family:var(--sans);font-size:13px;font-weight:700;letter-spacing:1.2px;text-transform:uppercase;color:#f4d9b8;margin:0 0 12px;}
.hours-row{display:flex;align-items:baseline;justify-content:space-between;font-size:17px;}
.hours-row .t{font-family:var(--serif);font-weight:700;font-size:22px;}

/* ---- CTA band ---- */
.cta h2{font-weight:700;font-size:38px;margin:0 0 14px;}
.cta p{font-size:18px;line-height:1.6;color:#f2e3d0;margin:0 auto 30px;}
.cta-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;}
.cta-round{border-radius:24px;padding:60px 48px;}

/* section titles */
.sec-head{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;margin-bottom:36px;}
.sec-head h2{font-weight:700;font-size:42px;letter-spacing:-.4px;margin:0;}
.link-more{color:var(--primary);font-weight:700;text-decoration:none;font-size:16px;white-space:nowrap;}
.link-more:hover{text-decoration:underline;}
.h2-center{font-weight:700;font-size:40px;letter-spacing:-.4px;margin:0 0 14px;text-align:center;}

/* ---- Responsive ---- */
@media(max-width:960px){
  .nav{display:none;position:absolute;top:100%;left:0;right:0;background:var(--cream);border-bottom:1px solid var(--line);flex-direction:column;align-items:flex-start;gap:0;padding:8px 32px 20px;}
  .nav.open{display:flex;}
  .nav a{padding:12px 0;width:100%;}
  .nav-toggle{display:block;}
  .hero,.pd,.feature,.about-feature,.contact,.reviews,.ig-grid{grid-template-columns:1fr;gap:32px;}
  .hero h1{font-size:46px;}
  .grid-4{grid-template-columns:repeat(2,1fr);}
  .grid-3{grid-template-columns:repeat(2,1fr);}
  .values,.steps{grid-template-columns:repeat(2,1fr);}
  .svc-big-grid,.svc-grid,.points{grid-template-columns:1fr;}
  .masonry{column-count:2;}
  .photo-grid{grid-template-columns:repeat(3,1fr);}
  .site-footer .cols{grid-template-columns:1fr;gap:28px;}
  .page-head h1,.pd h1{font-size:40px;}
  .field-row{grid-template-columns:1fr;}
}
@media(max-width:560px){
  .wrap{padding-left:20px;padding-right:20px;}
  .hero h1{font-size:38px;}
  .grid-4,.grid-3,.values,.steps,.photo-grid{grid-template-columns:1fr 1fr;}
  .hero h1{font-size:36px;}
  .h2-center,.sec-head h2{font-size:30px;}
}
