/* JD Softvera — Atelier design system (shared across all pages) */
*{margin:0;padding:0;box-sizing:border-box}
:root{
  --bone:#f3f0e8;--paper:#faf8f3;--ink:#121110;--ink2:#3a3733;--muted:#6f6a61;
  --line:#1211101a;--line2:#12111033;--accent:#2b3cff;--accent-d:#1f2bcc;
}
html{scroll-behavior:smooth}
body{font-family:'Inter',-apple-system,sans-serif;background:var(--bone);color:var(--ink);line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}
.wrap{max-width:1200px;margin:0 auto;padding:0 32px}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.serif{font-family:'Fraunces',Georgia,serif;font-weight:500;letter-spacing:-.01em;line-height:1.02}
.it{font-style:italic}
.ac{color:var(--accent)}
.label{font-size:12px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
.link{position:relative;font-weight:500}
.link::after{content:"";position:absolute;left:0;bottom:-3px;width:100%;height:1px;background:var(--ink);transform:scaleX(0);transform-origin:right;transition:transform .3s}
.link:hover::after{transform:scaleX(1);transform-origin:left}

/* buttons */
.arrow{display:inline-flex;align-items:center;gap:12px;font-weight:600;font-size:15px;border:1px solid var(--ink);border-radius:99px;padding:13px 25px;transition:.25s;cursor:pointer;background:none}
.arrow:hover{background:var(--ink);color:var(--bone)}
.arrow.solid{background:var(--ink);color:var(--bone)}
.arrow.solid:hover{background:var(--accent);border-color:var(--accent)}

/* nav */
nav{position:sticky;top:0;z-index:50;background:#f3f0e8e6;backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:76px}
.word{font-family:'Fraunces',serif;font-weight:600;font-size:23px;letter-spacing:-.01em;display:inline-flex;align-items:center;gap:10px}
.word .ast{color:var(--accent)}
.logo-mark{height:30px;width:auto;display:block;border-radius:7px}
.word.foot .logo-mark{height:26px}
.nav-links{display:flex;gap:30px;align-items:center}
.nav-links a{font-size:14px;color:var(--ink2)}
.nav-links a.active{color:var(--ink);font-weight:600}
.nav-links .cta{font-weight:600;color:var(--ink)}
.burger{display:none;background:none;border:none;font-size:24px;cursor:pointer}

/* page hero (inner pages) */
.phero{padding:72px 0 50px;border-bottom:1px solid var(--line)}
.phero .label{display:block;margin-bottom:24px}
.phero h1{font-size:clamp(40px,7vw,92px);font-weight:400}
.phero p{font-size:19px;color:var(--ink2);max-width:560px;margin-top:26px}

/* generic section */
section{position:relative}
.sec{padding:90px 0}
.shead{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;margin-bottom:46px;flex-wrap:wrap}
.shead h2{font-size:clamp(28px,4.6vw,52px);font-weight:400;max-width:620px}
.shead p{color:var(--muted);max-width:360px;font-size:16px}

/* capability rows */
.cap-row{display:grid;grid-template-columns:90px 1fr 1.1fr;gap:30px;align-items:start;padding:38px 0;border-top:1px solid var(--line);transition:.25s}
.cap-row:hover{padding-left:14px}
.cap-row:last-child{border-bottom:1px solid var(--line)}
.cap-row .num{font-family:'Fraunces',serif;font-size:22px;color:var(--accent)}
.cap-row h3{font-family:'Fraunces',serif;font-size:clamp(24px,3.4vw,38px);font-weight:500}
.cap-row p{color:var(--ink2);font-size:16px}
.cap-row .tags{margin-top:14px;display:flex;gap:8px;flex-wrap:wrap}
.cap-row .tags span{font-size:12px;color:var(--muted);border:1px solid var(--line);padding:4px 11px;border-radius:99px}

/* work tiles */
.work-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.tile{position:relative;border-radius:6px;overflow:hidden;min-height:330px;display:flex;flex-direction:column;justify-content:flex-end;padding:34px;color:#fff;transition:.3s}
.tile:hover{transform:translateY(-4px)}
.tile.t1{background:linear-gradient(150deg,#1a1d3a,#3a2b6e)}
.tile.t2{background:linear-gradient(150deg,#0f2e2a,#1d6e5a)}
.tile.t3{background:linear-gradient(150deg,#3a1a2e,#a8326b)}
.tile.t4{background:linear-gradient(150deg,#26221a,#7a5a2a)}
.tile.t5{background:linear-gradient(150deg,#1a2433,#2d5f8a)}
.tile.t6{background:linear-gradient(150deg,#2a1733,#6a2a8a)}
.tile .k{font-size:12px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;opacity:.8}
.tile h3{font-family:'Fraunces',serif;font-size:27px;font-weight:500;margin:8px 0 8px}
.tile p{font-size:14px;opacity:.85;max-width:340px}

/* marquee */
.marq{border-top:1px solid var(--line);border-bottom:1px solid var(--line);overflow:hidden;padding:20px 0}
.marq-track{display:flex;white-space:nowrap;animation:scroll 28s linear infinite;width:max-content}
.marq-track span{font-family:'Fraunces',serif;font-size:30px;padding:0 30px;display:inline-flex;align-items:center;gap:30px}
.marq-track span::after{content:"✦";color:var(--accent);font-size:16px}
@keyframes scroll{to{transform:translateX(-50%)}}

/* quote band */
.quote{padding:120px 0;text-align:center}
.quote p{font-family:'Fraunces',serif;font-size:clamp(26px,4.4vw,50px);font-weight:400;letter-spacing:-.02em;max-width:980px;margin:0 auto;line-height:1.16}

/* stat row */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:46px 0}
.stat .n{font-family:'Fraunces',serif;font-size:clamp(34px,4vw,54px);font-weight:500}
.stat .l{color:var(--muted);font-size:14px;margin-top:6px}

/* prose (about/insights) */
.prose{max-width:720px}
.prose p{font-size:18px;color:var(--ink2);margin-bottom:22px}
.prose h3{font-family:'Fraunces',serif;font-size:28px;font-weight:500;margin:38px 0 14px}

/* article list */
.posts{display:grid;gap:2px}
.post{display:grid;grid-template-columns:140px 1fr 130px;gap:24px;align-items:center;padding:28px 0;border-top:1px solid var(--line);transition:.2s}
.post:last-child{border-bottom:1px solid var(--line)}
.post:hover{padding-left:12px}
.post .cat{font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--accent)}
.post h3{font-family:'Fraunces',serif;font-size:24px;font-weight:500}
.post .date{color:var(--muted);font-size:14px;text-align:right}

/* contact */
.contact-big h2{font-size:clamp(40px,8vw,104px);font-weight:400;letter-spacing:-.03em}
.contact-row{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:30px;margin-top:40px}
.contact-row .det{font-size:17px;color:var(--ink2)}
.contact-row .det b{display:block;font-family:'Fraunces',serif;font-size:22px;color:var(--ink);font-weight:500;margin-top:6px}

/* form */
.form{display:grid;gap:18px;max-width:560px}
.form .field label{display:block;font-size:13px;font-weight:600;color:var(--ink2);margin-bottom:7px}
.form input,.form textarea,.form select{width:100%;padding:13px 15px;border:1px solid var(--line2);border-radius:10px;background:var(--paper);font-family:inherit;font-size:15px;color:var(--ink);outline:none;transition:.2s}
.form input:focus,.form textarea:focus,.form select:focus{border-color:var(--accent)}
.form textarea{min-height:130px;resize:vertical}

/* about images */
.imgrid{display:grid;grid-template-columns:2fr 1fr;grid-auto-rows:200px;gap:8px;margin-top:8px}
.imgwrap{border-radius:8px;overflow:hidden;background:#e6e1d6}
.imgwrap img{width:100%;height:100%;object-fit:cover;filter:grayscale(1) contrast(1.03);transition:filter .5s;display:block}
.imgwrap:hover img{filter:grayscale(0)}
.imgwrap.tall{grid-row:span 2}
.imgwrap.wide{grid-column:span 2}
.imcap{font-size:13px;color:var(--muted);margin-top:12px}

/* testimonials */
.tgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.tcard{border:1px solid var(--line);border-radius:18px;padding:32px;background:var(--paper);display:flex;flex-direction:column}
.tcard .stars{color:var(--accent);letter-spacing:4px;font-size:15px;margin-bottom:18px}
.tcard p{font-size:16px;color:var(--ink2);line-height:1.65;margin-bottom:24px}
.tcard .who{margin-top:auto;display:flex;align-items:center;gap:13px}
.tcard .av{width:44px;height:44px;border-radius:50%;background:var(--ink);color:var(--bone);display:flex;align-items:center;justify-content:center;font-family:'Fraunces',serif;font-weight:600;flex-shrink:0}
.tcard .nm{font-weight:600;font-size:15px}.tcard .rl{color:var(--muted);font-size:13px}

/* review screenshots */
.reviews{display:grid;grid-template-columns:repeat(auto-fit,minmax(440px,1fr));gap:20px}
.rev{border:1px solid var(--line);border-radius:16px;padding:22px;background:#fff;box-shadow:0 12px 34px #0f1b2d0c;transition:.2s}
.rev:hover{transform:translateY(-3px);box-shadow:0 18px 44px #0f1b2d14}
.rev img{width:100%;height:auto;border-radius:8px;display:block}
.rev figcaption{font-size:12px;color:var(--muted);margin-top:14px;display:flex;align-items:center;gap:7px}
.rev figcaption::before{content:"●";color:#2bb673;font-size:9px}
@media(max-width:560px){.reviews{grid-template-columns:1fr}}

/* about photo */
.photo{border-radius:16px;overflow:hidden;border:1px solid var(--line);box-shadow:0 18px 44px #0f1b2d12}
.photo img{width:100%;height:auto;display:block}

/* pricing */
.price-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.price{border:1px solid var(--line);border-radius:18px;padding:32px;background:var(--paper);display:flex;flex-direction:column}
.price.featured{border-color:var(--ink);box-shadow:0 18px 44px #0f1b2d12;position:relative}
.price.featured::after{content:"Most popular";position:absolute;top:-11px;left:32px;background:var(--ink);color:var(--bone);font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;padding:5px 12px;border-radius:99px}
.price .pname{font-family:'Fraunces',serif;font-size:24px;font-weight:500;margin-bottom:8px}
.price .pdesc{color:var(--muted);font-size:14px;margin-bottom:22px;min-height:42px}
.price .amt{font-family:'Fraunces',serif;font-size:38px;font-weight:500;line-height:1}
.price .amt small{font-size:15px;color:var(--muted);font-weight:400}
.price .per{color:var(--muted);font-size:13px;margin:6px 0 22px}
.price ul{list-style:none;margin-bottom:26px}
.price li{font-size:14px;color:var(--ink2);padding-left:24px;position:relative;margin-bottom:11px}
.price li::before{content:"✓";position:absolute;left:0;color:var(--accent);font-weight:700}
.price .arrow{margin-top:auto;justify-content:center}
.retainer{margin-top:22px;border:1px dashed var(--line2);border-radius:16px;padding:28px 32px;display:flex;justify-content:space-between;align-items:center;gap:24px;flex-wrap:wrap}
.retainer h3{font-family:'Fraunces',serif;font-size:24px;font-weight:500}
.retainer p{color:var(--muted);font-size:15px;max-width:520px;margin-top:6px}
.pricenote{color:var(--muted);font-size:14px;margin-top:26px;max-width:760px;line-height:1.6}

/* legal pages */
.legal{max-width:760px}
.legal h2{font-family:'Fraunces',serif;font-size:25px;font-weight:500;margin:38px 0 12px}
.legal h2:first-child{margin-top:0}
.legal p,.legal li{font-size:16px;color:var(--ink2);line-height:1.75;margin-bottom:14px}
.legal ul{padding-left:22px;margin-bottom:16px}
.legal li{margin-bottom:8px}
.legal a{color:var(--accent)}
.legal .updated{color:var(--muted);font-size:14px;margin-bottom:8px}

.legal-links a{margin-left:16px}
.legal-links a:first-child{margin-left:0}

@media(max-width:880px){.price-grid{grid-template-columns:1fr}}

/* footer */
footer{padding:70px 0 44px;border-top:1px solid var(--line);margin-top:40px}
.fgrid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:30px;margin-bottom:46px}
.fgrid h4{font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-bottom:16px}
.fgrid a{display:block;color:var(--ink2);font-size:15px;margin-bottom:10px}
.fgrid a:hover{color:var(--ink)}
.fgrid .blurb{color:var(--ink2);font-size:15px;max-width:280px;margin-top:14px}
.fbar{display:flex;justify-content:space-between;flex-wrap:wrap;gap:16px;border-top:1px solid var(--line);padding-top:26px;color:var(--muted);font-size:14px}

@media(max-width:880px){
  .nav-links{position:fixed;inset:76px 0 auto 0;background:var(--bone);flex-direction:column;gap:0;padding:10px 0;border-bottom:1px solid var(--line);display:none}
  .nav-links.open{display:flex}
  .nav-links a{padding:14px 32px;width:100%}
  .burger{display:block}
  .cap-row{grid-template-columns:50px 1fr;gap:16px}.cap-row p,.cap-row .tags{grid-column:2}
  .work-grid{grid-template-columns:1fr}
  .stats{grid-template-columns:repeat(2,1fr)}
  .post{grid-template-columns:1fr;gap:8px}.post .date{text-align:left}
  .fgrid{grid-template-columns:1fr 1fr}
  .tgrid{grid-template-columns:1fr}
  .imgrid{grid-template-columns:1fr;grid-auto-rows:180px}.imgwrap.wide{grid-column:auto}
}
